1

目前我正在开发一个系统,在该系统中,我必须触发 100 个相互依赖的查询,例如,

在我的脚本中(目前正在执行),

$query1 = mysql_query("INSERT_QUERY_STRING");
if(!$query) {
    die('error'.mysql_error());
}

//this loop can be turn more than 100 times

while(CONDITION) {
    //query generated here
    $query2 = mysql_query("UPDATE_QUERY_STRING");
    $query3 = mysql_query("UPDATE_QUERY_STRING");
    $query4 = mysql_query("UPDATE_QUERY_STRING");
    $query5 = mysql_query("UPDATE_QUERY_STRING");

    if(!$query2 || !$query3 || !$query4 || !$query5) {
        die('error '.mysql_error());
    }
}

$query6 = mysql_query("UPDATE_QUERY_STRING");
if(!$query6) {
    die('error '.mysql_error());
}

忽略语法错误,这只是一个逻辑

问题是,由于所有查询都是相互依赖的,如果一个查询失败,那么之前发生的所有更改都应该被撤销。我知道一种使用 MYSQL 事务、提交和回滚的解决方案。这是我想出来的(计划这样做),

$processes = array();

$processes[] = "INSERT_QUERY_STRING"; //query1

//this loop can be turn more than 100 times

while(CONDITION) {
    //query generated here
    $processes[] = "UPDATE_QUERY_STRING"; //looping queries
}

$processes[] = "UPDATE_QUERY_STRING" //last query

mysql_query("SET AUTOCOMMIT=0");
mysql_query("START TRANSACTION");    
$error = false;
for($i=0;$i < count($processes) ; $i++)
{
    $q = mysql_query($processes[$i]);
    if(!$q) {
        $error = true;
        break;
    }
}

if($error == false) {
    mysql_query("COMMIT");
}
else {
    mysql_query("ROLLBACK");
}

我的解决方案是好/最好的吗?有没有其他可能的解决方案可以更快更有效地做同样的事情?谢谢。

4

2 回答 2

2

我认为在旅游代码中使用 try/catch 会更好:

$processes = array();

$processes[] = "INSERT_QUERY_STRING"; //query1

//this loop can be turn more than 100 times

while(CONDITION) {
    //query generated here
    $processes[] = "UPDATE_QUERY_STRING"; //looping queries
}

$processes[] = "UPDATE_QUERY_STRING"; //last query

mysql_query("SET AUTOCOMMIT=0");
mysql_query("START TRANSACTION");  

$count_processes = count($processes);

for($i=0; $i < $count_processes; $i++)
{
    try {
        $q = mysql_query($processes[$i]);
        if (!$q) throw new Exception(mysql_error());
    }
    catch (Exception $e) {
        mysql_query("ROLLBACK");
        break;
    }
}

mysql_query("COMMIT");
mysql_query("SET AUTOCOMMIT=1");

使用 try/catch 更好,因为您可以控制代码和错误 :)

于 2013-07-17T10:17:27.367 回答
1

交易绝对是去这里的最佳方式。我将插入查询放在 try-catch 语句中以涵盖不可预测的情况并使用 foreach 遍历 $processes

于 2013-07-17T10:10:21.643 回答