编程语言您现在的位置是:首页 > 博客日志 > 编程语言

php mysql开启多条语句执行,mysql怎么一次执行多条SQL语句?

<a href='mailto:'>微wx笑</a>的头像微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 执行会报错,BCn无知

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'BCn无知

但是单独将$sql里面的内容放在phpmyadmin中执行是正确的,这是什么原因呢?BCn无知


BCn无知

mysql_query不支持同时运行多条SQL。你要以;号拆开分别执行BCn无知

如果要同时执行这些sql的话,不能用;隔开一起执行,只能一个一个的执行,或者将这些sql放入一个数组,然后循环执行,建议加上事务处理BCn无知

但是这样就违背了一次执行多条,解决速度慢的初衷。BCn无知


BCn无知

解决方法:BCn无知

使用 mysqli_multi_queryBCn无知

BCn无知

定义和用法

mysqli_multi_query() 函数执行一个或多个针对数据库的查询。多个查询用分号进行分隔。BCn无知


语法

mysqli_multi_query(connection,query);


BCn无知

参数描述
connection必需。规定要使用的 MySQL 连接。
query必需。规定一个或多个查询,用分号进行分隔。

技术细节

返回值:如果第一个查询失败则返回 FALSE。
PHP 版本:5+

示例代码:BCn无知

<?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);
?>

相关参考:BCn无知

https://www.php.net/manual/zh/mysqli.multi-query.php BCn无知


BCn无知

本文由 微wx笑 创作,采用 署名-非商业性使用-相同方式共享 4.0 许可协议,转载请附上原文出处链接及本声明。
原文链接:https://www.ivu4e.cn/blog/lang/2023-01-06/1640.html

很赞哦! () 有话说 ()