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



