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

本文介绍了一种使用PHP批量执行SQL文件中的多条CREATE TABLE等语句的方法。通过正则表达式拆分SQL语句并逐一执行,适用于程序初始化或导入备份文件时创建数据表。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

正常情况下用php的mysql_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>';用来查看是否有错误;

白俊遥博客


转载于:https://my.oschina.net/u/2296413/blog/652433

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值