PHP执行批量mysql语句的解决方法
2015-01-24信息快讯网
本篇文章介绍了,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 file_get_contents设置超时处理方法
PHP 验证码不显示只有一个小红叉的解决方法
Zend studio文件注释模板设置方法
php 获取今日、昨日、上周、本月的起始时间戳和结束时间戳的方法
php中time()和mktime()方法的区别
PHP Switch 语句之学习笔记
PHP连接局域网MYSQL数据库的简单实例
PHP mysql与mysqli事务使用说明 分享
测试PHP连接MYSQL成功与否的代码
php读取mysql中文数据出现乱码的解决方法
php使用sql数据库 获取字段问题介绍
浅析Mysql 数据回滚错误的解决方法
php中使用$_REQUEST需要注意的一个问题
PHP闭包(Closure)使用详解
基于php上传图片重命名的6种解决方法的详细介绍
PHP基础之运算符的使用方法
php无限极分类实现的两种解决方法
基于ubuntu下nginx+php+mysql安装配置的具体操作步骤
php gzip压缩输出的实现方法
php二维数组排序与默认自然排序的方法介绍
Php中用PDO查询Mysql来避免SQL注入风险的方法
php中防止SQL注入的最佳解决方法
PHP 读取Postgresql中的数组
PHP If Else(elsefi) 语句
php更新mysql后获取影响的行数发生异常解决方法
php并发对MYSQL造成压力的解决方法
php中存储用户ID和密码到mysql数据库的方法
mysql 查询指定日期时间内sql语句实现原理与代码
PHP文章按日期(月日)SQL归档语句
PHP数组及条件,循环语句学习
php循环语句 for()与foreach()用法区别介绍