php mysql开启多条语句执行,mysql怎么一次执行多条SQL语句?
微wx笑
2023-01-06【编程语言】
89
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+ |
示例代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | <?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