php mysql开启多条语句执行,mysql怎么一次执行多条SQL语句?
微wx笑 2023-01-06【编程语言】 6 0关键字: php mysql
将多条SQL语句使用分号分隔放在一个字符串中使用 mysql_query 执行会报错,
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '\xE7'
但是单独将$sql里面的内容放在phpmyadmin中执行是正确的,这是什么原因呢?
将多条SQL语句使用分号分隔放在一个字符串中使用 mysql_query 执行会报错,
但是单独将$sql里面的内容放在phpmyadmin中执行是正确的,这是什么原因呢?
mysql_query不支持同时运行多条SQL。你要以;号拆开分别执行
如果要同时执行这些sql的话,不能用;隔开一起执行,只能一个一个的执行,或者将这些sql放入一个数组,然后循环执行,建议加上事务处理
但是这样就违背了一次执行多条,解决速度慢的初衷。
解决方法:
使用 mysqli_multi_query
定义和用法
mysqli_multi_query() 函数执行一个或多个针对数据库的查询。多个查询用分号进行分隔。
语法
参数 | 描述 |
---|---|
connection | 必需。规定要使用的 MySQL 连接。 |
query | 必需。规定一个或多个查询,用分号进行分隔。 |
技术细节
返回值: | 如果第一个查询失败则返回 FALSE。 |
---|---|
PHP 版本: | 5+ |
示例代码:
<?php $con=mysqli_connect("localhost","my_user","my_password","my_db"); // 检测链接 if (mysqli_connect_errno($con)) { echo "连接到 MySQL 失败: " . mysqli_connect_error(); } $sql = "SELECT Lastname FROM Persons ORDER BY LastName;"; $sql .= "SELECT Country FROM Customers"; // 执行多个 SQL 语句 if (mysqli_multi_query($con,$sql)) { do { // 存储第一个结果集 if ($result=mysqli_store_result($con)) { while ($row=mysqli_fetch_row($result)) { printf("%sn",$row[0]); } mysqli_free_result($result); } } while (mysqli_next_result($con)); } mysqli_close($con); ?>
相关参考:
https://www.php.net/manual/zh/mysqli.multi-query.php
本文由 微wx笑 创作,采用 署名-非商业性使用-相同方式共享 4.0 许可协议,转载请附上原文出处链接及本声明。
原文链接:https://www.ivu4e.cn/blog/lang/2023-01-06/1640.html