手机
当前位置:查字典教程网 >编程开发 >php教程 >PHP执行批量mysql语句的解决方法
PHP执行批量mysql语句的解决方法
摘要:当有多条mysql语句连起来需要执行,比如$sqls=“inserttableavalues(1,2);inserttableavalues...

当有多条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 "rn";

break;

}

}

$mysqli->close();

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

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

【PHP执行批量mysql语句的解决方法】相关文章:

Mac环境下php操作mysql数据库的方法分享

php从文件夹随机读取文件的方法

PHP生成唯一订单号的方法汇总

PHP rsa加密解密使用方法

PHP ajax 异步执行不等待执行结果的处理方法

PHP4与PHP3中一个不兼容问题的解决方法

PHP下MAIL的另一解决方案

PHP获取文件行数的方法

PHP file_get_contents函数读取远程数据超时的解决方法

PHP查找与搜索数组元素方法总结

精品推荐
分类导航