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的指令碼的話,這招就非常好用了。
相關文章
- sql語句批量執行SQL
- php連線mysql並執行sql語句PHPMySql
- 讓dede執行php程式碼和mysql語句PHPMySql
- mySQL 執行語句執行順序MySql
- MySQL語句執行分析(一)MySql
- MySQL語句執行分析(二)MySql
- mysql執行sql語句過程MySql
- mysql的sql語句執行流程MySql
- MySQL cron定時執行SQL語句MySql
- php中對MYSQL操作之批量執行,與獲取批量結果PHPMySql
- MySQL 批量殺mysql執行緒MySql執行緒
- MYSQL 中 exists 語句執行效率變低MySql
- mysql sql語句執行超時設定MySql
- mysql如何跟蹤執行的sql語句MySql
- 檢視mysql正在執行的SQL語句MySql
- linux strace追蹤mysql執行語句LinuxMySql
- 如何向mysql中批量插入大量sql語句MySql
- php如何嫵媚地生成執行的sql語句PHPSQL
- MySQL 執行DDL語句 hang住了怎麼辦?MySql
- MySQL 查詢語句執行過程淺析MySql
- MySQL:一條更新語句是如何執行的MySql
- MySql定位執行效率較低的SQL語句MySql
- c#實現用SQL池(多執行緒),定時批量執行SQL語句 (轉)C#SQL執行緒
- PHP+MySQL 手工注入語句大全PHPMySql
- for語句執行順序
- FORALL執行DELETE語句delete
- FORALL執行UPDATE語句
- 100% 展示 MySQL 語句執行的神器-Optimizer TraceMySql
- 一條SQL語句在MySQL中如何執行的MySql
- 查詢正在執行的sql語句及該語句執行的時間SQL
- 一條sql語句在mysql中是如何執行的MySql
- MySQL探祕(二):SQL語句執行過程詳解MySql
- 檢視mysql連線數 sql語句執行時間MySql
- sql語句如何執行的SQL
- SQL語句執行順序SQL
- FORALL執行UPDATE語句(二)
- 執行大的sql語句SQL
- toad執行sql語句SQL