php - MySQL 事务语法错误

标签 php mysql syntax transactions

下面是一个语法错误。整个查询在带有文字的 MySQL 客户端中工作,但在从 PHP 传递时会中断。在 PHP 中,如果单独提交,则每个查询都有效,但如果在 STARTCOMMIT 中则无效。

错误:

1064: You have an error in your SQL syntax; check the manual ...etc...right
syntax to use near 'INSERT INTO user_degrees (user_id, degree_id, acadcat_id
, inst_id) VALUES (' at line 2

查询:

$query="START TRANSACTION;

INSERT INTO user_degrees (user_id, degree_id, acadcat_id, inst_id) 
VALUES ((SELECT id FROM users WHERE users.username = '$user')
   , '$degreeid', '$studyfocus', '$institution');

UPDATE users 
SET degree".$dnum." = (SELECT LAST_INSERT_ID())
WHERE username = '$user';

COMMIT;";

所有 $vars 都是类属性并传递整数,除了 $user,它传递用户名 session 变量。 $dnum 用于更改类实例之间的列名,我可能在 MySQL 中错误地连接了它。

最佳答案

PHP 的 mysql 驱动程序仅允许每次 mysql_query() 调用作为安全措施进行一次查询。您必须发出多个单独的查询:

$result = mysql_query("START TRANSACTION");
$result = mysql_query("INSERT ...");
$result = mysql_query("UPDATE ...");
$result = mysql_query("COMMIT;");

...在每个阶段进行适当的检查以确保查询没有失败(我从这里省略了)。

请注意,此安全措施仅适用于顶级查询。每次调用一对一的顶级查询。您可以根据需要拥有任意数量的子查询。

关于php - MySQL 事务语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8141714/

相关文章:

PHP 和 MySQL 图片一键 ActionScript

mysql - 我不明白 mysql 语法有什么问题

c++ - 具有多线程成员函数的类

php - 如果新值在数组中,如何批量更新数据库? PHP

javascript - es6 在 IF 中声明一个变量(如 es5 )

c++ - 为 STL 类编写迭代器函数

PHP SoapClient 将数组转换为字符串

javascript - 如何使用 POST 方法将 javascript/jQuery 变量传递给 PHP

javascript - 淡化域之间的页面转换

mysql - Microsoft Access SQL查询两个表多对一