目前我正在开发一个系统,在该系统中,我必须触发 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");
}
我的解决方案是好/最好的吗?有没有其他可能的解决方案可以更快更有效地做同样的事情?谢谢。