我正在尝试从上次查询中获取自动增量ID并更新同一行。此外,我想保留事务中的所有内容,并在出现问题时抛出用户友好的错误。你能帮忙吗?
$parentSQL = "INSERT INTO TABLE1(test1, test2) VALUES ('" .$test1. "', '" .$test2. "')";
$result = mysql_query($parentSQL) or die(mysql_error());
$newId = MySql_Insert_Id();
$val = "MU".$newId;
$updateSQL = "UPDATE TABLE1 SET test3 = '" .$val. "' WHERE id= ".$newId." ";
$updateResult = mysql_query($updateSQL) or die(mysql_error());
$childSQL = "INSERT INTO TABLE2(testId, testCol) VALUES (" .$newId. ", '" .$testCol. "')";
$childResult = mysql_query($childSQL) or die(mysql_error());
答案 0 :(得分:1)
这只是一个建议,但为什么不尝试使用存储过程?
在MySQL中
DELIMITER //
CREATE PROCEDURE test (
IN param1 VARCHAR(20)
, IN param2 VARCHAR(20)
, IN param3 VARCHAR(20)
, IN param4 VARCHAR(20)
)
BEGIN
INSERT INTO TABLE1(test1, test2) VALUES (param1, param2);
UPDATE TABLE1 SET test3 = CONCAT(param3, LAST_INSERT_ID());
INSERT INTO TABLE2(testId, testCol) VALUES (LAST_INSERT_ID(), param4);
END//
DELIMITER ;
在PHP中,并使用 PDO 来使用预准备语句:
$q = $db->prepare("CALL test (?,?,?,?)");
$q->bindParam(1, $test1);
$q->bindParam(2, $test2);
$q->bindParam(3, $val);
$q->bindParam(4, $testCol);
$q->execute();
答案 1 :(得分:0)
您是否只想在交易中查询?如果是,请将查询调用放在:
之间mysql_query('START TRANSACTION');
// your queries
mysql_query('COMMIT');
不确定我完全明白你的问题究竟是什么。 见http://dev.mysql.com/doc/refman/5.0/fr/commit.html