PHP执行批量mysql语句的解决方法

前端之家收集整理的这篇文章主要介绍了PHP执行批量mysql语句的解决方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

当有多条MysqL语句连起来需要执行,比如

$sqls= “insert table a values(1,2); insert table a values(2,3);”

需要执行的话PHP中可以使用的方法有三个:

MysqL_query

pdo

MysqLi

三种方法sqls语句没有问题的时候都是可以的。

但是

sql语句是错误的时候会出现问题
第一条sql错误:三个方法都返回false

第一条sql正确,第二条sql错误MysqL_query、pdo、 MysqLi:query也是返回true。所以这个时候你是没法判断你的sqls是否有那条语句是错误的。


解决这种办法有几个招:

1 解析sql语句

将每条sql都拆分开来执行。这样每个语句分开执行就解决了。但是这种方法多出了好几种方法,所以不可取。

2 将sqls语句保存为文本

使用cmd执行命令 MysqL…. .< sqls.sql,然后捕获输出。这也是一种方法,但是感觉是绕着问题走,应该还有更好的方法

3 使用MysqLi::multi_query方法

这个方法可以执行多条sql语句,然后使用MysqLi::next_result来设置sql的偏移量,使用MysqLi::error获取当前偏移的sql错误状态

下面是第三种方法的示例代码

代码如下:

代码如下:
$sql = Config::get('sql');
$content = file_get_contents($sql);
$config = Config::get('config')
$MysqLi = MysqLi_connect($config['host'],$config['user'],$config['password'],$config['dbname']);
$ret = $MysqLi->multi_query($content);
if($ret === false) {
echo MysqLi_error($MysqLi);
}
while (MysqLi_more_results($MysqLi)) {
if (MysqLi_next_result($MysqLi) === false) {
echo MysqLi_error($MysqLi);
echo "\r\n";
break;
}
}
$MysqLi->close();

这样的话当sqls语句中任意一条有错误的话,程序就会跳出这个错误

如果你要编写初始化MysqL的脚本的话,这招就非常好用了。

猜你在找的PHP相关文章