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 " ;
break ;
}
} $mysqli ->close();
|
這樣的話當sqls語句中任意一條有錯誤的話,程式就會跳出這個錯誤。
如果你要編寫初始化mysql的指令碼的話,這招就非常好用了。
相關文章
- mySQL 執行語句執行順序MySql
- MySQL語句執行分析(一)MySql
- MySQL語句執行分析(二)MySql
- mysql的sql語句執行流程MySql
- mysql 語句的執行順序MySql
- mysql執行sql語句過程MySql
- MySQL cron定時執行SQL語句MySql
- mysql sql語句執行超時設定MySql
- MYSQL 中 exists 語句執行效率變低MySql
- MySQL 執行DDL語句 hang住了怎麼辦?MySql
- 100% 展示 MySQL 語句執行的神器-Optimizer TraceMySql
- MySQL 查詢語句執行過程淺析MySql
- MySQL:一條更新語句是如何執行的MySql
- PHP+MySQL 手工注入語句大全PHPMySql
- 一條SQL語句在MySQL中如何執行的MySql
- 當執行一條select語句時,MySQL到底做了啥?MySql
- MySQL探祕(二):SQL語句執行過程詳解MySql
- 一條sql語句在mysql中是如何執行的MySql
- 一條 SQL 語句在 MySQL 中是如何執行的?MySql
- SQL語句執行順序SQL
- sql語句如何執行的SQL
- Select語句執行順序
- 一個 MySQL sql 語句執行順序帶來的 bugMySql
- MySQL日誌(一條sql更新語句是如何執行的)MySql
- 查詢Oracle正在執行的sql語句及執行該語句的使用者OracleSQL
- sql語句執行緩慢分析SQL
- SQL 語句的執行順序SQL
- 後臺執行SQL語句(oracle)SQLOracle
- takes_ownership(s)語句執行
- python怎樣執行js語句PythonJS
- Mybatis 動態執行SQL語句MyBatisSQL
- mysql語句MySql
- MySQL系列之一條SQL查詢語句的執行過程MySql
- MySQL全文索引原始碼剖析之Insert語句執行過程MySql索引原始碼
- 面試官:MySQL 是如何執行一條查詢語句的?面試MySql
- MySQL 查詢常用操作(0) —— 查詢語句的執行順序MySql
- 深入解讀MySQL InnoDB儲存引擎Update語句執行過程MySql儲存引擎
- MySQL 記錄所有執行了的 sql 語句MySql
- Laravel 獲取執行的sql語句LaravelSQL