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


Posted in PHP onMay 02, 2013

当有多条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 相关文章推荐
怎样在UNIX系统下安装php3
Oct 09 PHP
PHP批量生成缩略图的代码
Jul 19 PHP
PHP 加密/解密函数 dencrypt(动态密文,带压缩功能,支持中文)
Jan 30 PHP
PHP数组循环操作详细介绍 附实例代码
Feb 03 PHP
PHP 面向对象程序设计(oop)学习笔记 (五) - PHP 命名空间
Jun 12 PHP
PHP将字符分解为多个字符串的方法
Nov 22 PHP
php返回相对时间(如:20分钟前,3天前)的方法
Apr 14 PHP
php中header跳转使用include包含解决参数丢失问题
May 08 PHP
php倒计时出现-0情况的解决方法
Jul 28 PHP
php微信开发之自定义菜单实现
Nov 18 PHP
Django 标签筛选的实现代码(一对多、多对多)
Sep 05 PHP
php计数排序算法的实现代码(附四个实例代码)
Mar 31 PHP
PHP闭包(Closure)使用详解
May 02 #PHP
PHP5中Cookie与 Session使用详解
Apr 30 #PHP
PHP容易忘记的知识点分享
Apr 30 #PHP
基于curl数据采集之正则处理函数get_matches的使用
Apr 28 #PHP
基于curl数据采集之单页面并行采集函数get_htmls的使用
Apr 28 #PHP
基于curl数据采集之单页面采集函数get_html的使用
Apr 28 #PHP
基于php上传图片重命名的6种解决方法的详细介绍
Apr 28 #PHP
You might like
Notice: Trying to get property of non-object problem(PHP)解决办法
2012/03/11 PHP
PHP中soap的用法实例
2014/10/24 PHP
Laravel5.4框架使用socialite实现github登录的方法
2019/03/20 PHP
laravel 使用事件系统统计浏览量的实现
2019/10/16 PHP
javascript 跳转代码集合
2009/12/03 Javascript
JavaScript 字符串处理函数使用小结
2010/12/02 Javascript
js加载读取内容及显示与隐藏div示例
2014/02/13 Javascript
原生JavaScript实现合并多个数组示例
2014/09/21 Javascript
JavaScript实现的简单拖拽效果
2015/06/01 Javascript
jquery实现简单的二级导航下拉菜单效果
2015/09/07 Javascript
JS实现网页标题栏显示当前时间和日期的完整代码
2015/11/02 Javascript
使用EVAL处理jqchart jquery 折线图返回数据无效的解决办法
2015/11/26 Javascript
下一代Bootstrap的5个特点 超酷炫!
2016/06/17 Javascript
JS 动态加载js文件和css文件 同步/异步的两种简单方式
2016/09/23 Javascript
微信小程序 生命周期详解
2016/10/12 Javascript
Mobile Web开发基础之四--处理手机设备的横竖屏问题
2017/08/11 Javascript
浅谈Angular2 ng-content 指令在组件中嵌入内容
2017/08/18 Javascript
nodejs socket服务端和客户端简单通信功能
2017/09/14 NodeJs
详解webpack loader和plugin编写
2018/10/12 Javascript
javascript中floor使用方法总结
2019/02/02 Javascript
详解Webpack如何引入CDN链接来优化编译后的体积
2019/06/21 Javascript
javascript实现下拉菜单效果
2021/02/09 Javascript
[02:49]2014DOTA2电竞也是体育项目! 势要把荣誉带回中国!
2014/07/20 DOTA
[01:19:33]DOTA2-DPC中国联赛 正赛 iG vs VG BO3 第一场 2月2日
2021/03/11 DOTA
Python批量创建迅雷任务及创建多个文件
2016/02/13 Python
详解Python3操作Mongodb简明易懂教程
2017/05/25 Python
python的re正则表达式实例代码
2018/01/24 Python
TensorFlow 合并/连接数组的方法
2018/07/27 Python
python面向对象入门教程之从代码复用开始(一)
2018/12/11 Python
Python之NumPy(axis=0 与axis=1)区分详解
2019/05/27 Python
django 基于中间件实现限制ip频繁访问过程详解
2019/07/30 Python
HTML5 Canvas——用路径描画线条实例介绍
2013/06/09 HTML / CSS
师范应届毕业生自荐信
2013/11/18 职场文书
购房协议书范本
2014/04/11 职场文书
四十九个javascript小知识实用技巧
2021/11/20 Javascript
Go微服务项目配置文件的定义和读取示例详解
2022/06/21 Golang