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的错误状态

 

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

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$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的脚本的话,这招就非常好用了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值