尝试catch,以及多个mysql insert语句。它会接受全部还是否认所有疑问?

时间:2013-10-24 18:37:53

标签: php mysql sql transactions try-catch

嘿,我向你们提问。如果我在try catch中实现我的sql mysql insert会阻止只有部分INSERT执行到数据库中,如果其中一个会失败?

try
{
//SQL INSET TABLE 1
//SQL INSET TABLE 2
//SQL INSET TABLE 3
//SQL INSET TABLE 4
}
catch(Exception $e)
{...}

我想否认所有人或接受所有人。他们是这样做的吗?

关于你的评论。我正在使用PDO。我将非常感谢能够实现的配置示例。

在您的评论中,您经常建议进行交易和回滚。任何人都可以举例说明代码吗? X

我还想知道是否有其他方法可以达到这种效果。

@SOLUTION找到了:PHP + MySQL transactions examples

try {
    // First of all, let's begin a transaction
    $db->beginTransaction();

    // A set of queries; if one fails, an exception should be thrown
    $db->query('first query');
    $db->query('second query');
    $db->query('third query');

    // If we arrive here, it means that no exception was thrown
    // i.e. no query has failed, and we can commit the transaction
    $db->commit();
} catch (Exception $e) {
    // An exception has been thrown
    // We must rollback the transaction
    $db->rollback();
}

请注意,有了这个想法,如果查询失败,则必须抛出异常:

PDO可以这样做,具体取决于您的配置方式 请参见PDO :: setAttribute 和PDO :: ATTR_ERRMODE和PDO :: ERRMODE_EXCEPTION 否则,使用其他API,您可能必须测试用于执行查询的函数的结果,并自己抛出异常。

不幸的是,没有任何魔法涉及。您不能只是在某处放置指令并自动完成事务:您仍然必须具体说明必须在事务中执行哪组查询。

例如,通常在事务之前(开始之前)和事务之后的另外几个查询(在提交或回滚之后)会有一些查询,并且您将希望执行这些查询而不管是什么在交易中发生了(或没有)。

另一个有用的链接:PHP PDO Transactions?

2 个答案:

答案 0 :(得分:3)

没有。如果其中一个失败,try/catch将不会“撤消”失败的查询。您需要一个交易:

try {
   start transaction;
   insert 1;
   insert 2;
   ...
   commit;
} catch {
   rollback;
}

答案 1 :(得分:1)

你应该在catch块中使用事务和回滚。