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的腳本的話,這招就非常好用了。
本文轉自軒脈刃博客園博客,原文鏈接:http://www.cnblogs.com/yjf512/archive/2012/11/06/2757052.html,如需轉載請自行聯系原作者
總結
以上是生活随笔為你收集整理的PHP执行批量mysql语句的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Kotlin系列之类和属性
- 下一篇: Linux IO模型漫谈(1)