1

嘿,我有问题要问你们。如果我在 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 事务示例

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 事务?

4

2 回答 2

3

try/catch,如果其中之一失败,将不会“撤消”失败的查询。你需要一笔交易:

try {
   start transaction;
   insert 1;
   insert 2;
   ...
   commit;
} catch {
   rollback;
}
于 2013-10-24T18:39:40.283 回答
1

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

于 2013-10-24T18:40:27.550 回答