php函数mysql_query批量执行多句sql语句

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php函数mysql_query批量执行多句sql语句相关的知识,希望对你有一定的参考价值。

正常情况下用phpmysql_query函数是不能批量执行多句CREATE TABLE之类的语句的;

而有些场景;比如说有一个sql备份文件、又或是程序初始化时创建数据表结构的时候需要批量执行文件中的sql语句;

解决这个问题可以用explode函数按‘;‘号把sql语句拆成数组;再通过循环执行mysql_query即可;因为每句sql都是以‘;‘号结束的;

但是考虑到sql语句中可能有实体符号  之类的;如果按‘;‘号来拆;容易误伤;所以用preg_split正则来拆更靠谱;

示例环境:

sql文件:./thinkbjy.sql

        $sql_array=preg_split("/;[\r\n]+/", file_get_contents(‘./thinkbjy.sql‘));
        foreach ($sql_array as $k => $v) {
           mysql_query($v,$link);
           echo mysql_error().‘<br>‘;
        }

执行 echo mysql_error().‘<br>‘;用来查看是否有错误;

技术分享


以上是关于php函数mysql_query批量执行多句sql语句的主要内容,如果未能解决你的问题,请参考以下文章

Python pymysql是否能执行在一个字符串里面的多句SQL

PHP中如何判断SQL语句是不是成功执行?

php合并单元格

PHP中的mysql_query()函数的返回值是啥?

PHP获取MySQL执行sql语句的查询时间

PHP如何批量更新数据?急!!!