MySQL 一次執(zhí)行多條語(yǔ)句的實(shí)現(xiàn)及常見(jiàn)問(wèn)題
更新時(shí)間:2009年08月15日 02:04:26 作者:
通常情況MySQL出于安全考慮不允許一次執(zhí)行多條語(yǔ)句(但也不報(bào)錯(cuò),很讓人郁悶)。
MySQL是支持在單個(gè)查詢(xún)字符串中指定多語(yǔ)句執(zhí)行的,使用方法是給鏈接指定參數(shù):
//鏈接時(shí)設(shè)定
mysql_real_connect( ..., CLIENT_MULTI_STATEMENTS );
//或者
//中途指定
mysql_set_server_option( mysql, MYSQL_OPTION_MULTI_STATEMENTS_ON ); //mysql是連接的名稱(chēng)
當(dāng)使用執(zhí)行多語(yǔ)句功能后,一定要讀完整個(gè)resault集,否則會(huì)出現(xiàn)錯(cuò)誤:Commands out of sync; you can't run this command now
官方推薦的執(zhí)行語(yǔ)句是這樣的:
do
{
/* Process all results */
...
printf( "total affected rows: %lld", mysql_affected_rows( mysql ) );
...
if( !( result mysql_store_result( mysql ) ) )
{
printf( stderr, "Got fatal error processing query\n" );
exit(1);
}
process_result_set(result); /* client function */
mysql_free_result(result);
}while( !mysql_next_result( mysql ) );
如果僅僅是插入等不需要返回值的SQL語(yǔ)句,也一樣得讀完整個(gè)resault集并釋放,最小化的寫(xiě)法:
do
{
result = mysql_store_result( mysql );
mysql_free_result(result);
}while( !mysql_next_result( mysql ) );
復(fù)制代碼 代碼如下:
//鏈接時(shí)設(shè)定
mysql_real_connect( ..., CLIENT_MULTI_STATEMENTS );
//或者
//中途指定
mysql_set_server_option( mysql, MYSQL_OPTION_MULTI_STATEMENTS_ON ); //mysql是連接的名稱(chēng)
當(dāng)使用執(zhí)行多語(yǔ)句功能后,一定要讀完整個(gè)resault集,否則會(huì)出現(xiàn)錯(cuò)誤:Commands out of sync; you can't run this command now
官方推薦的執(zhí)行語(yǔ)句是這樣的:
復(fù)制代碼 代碼如下:
do
{
/* Process all results */
...
printf( "total affected rows: %lld", mysql_affected_rows( mysql ) );
...
if( !( result mysql_store_result( mysql ) ) )
{
printf( stderr, "Got fatal error processing query\n" );
exit(1);
}
process_result_set(result); /* client function */
mysql_free_result(result);
}while( !mysql_next_result( mysql ) );
如果僅僅是插入等不需要返回值的SQL語(yǔ)句,也一樣得讀完整個(gè)resault集并釋放,最小化的寫(xiě)法:
復(fù)制代碼 代碼如下:
do
{
result = mysql_store_result( mysql );
mysql_free_result(result);
}while( !mysql_next_result( mysql ) );
您可能感興趣的文章:
- MySQL無(wú)法啟動(dòng)幾種常見(jiàn)問(wèn)題小結(jié)
- 常見(jiàn)php與mysql中文亂碼問(wèn)題解決辦法
- mysql安裝時(shí)出現(xiàn)各種常見(jiàn)問(wèn)題的解決方法
- CentOS下PHP7的編譯安裝及MySQL的支持和一些常見(jiàn)問(wèn)題的解決辦法
- 在EF中使用MySQL的方法及常見(jiàn)問(wèn)題
- mysql常見(jiàn)的錯(cuò)誤提示問(wèn)題處理小結(jié)
- Mysql常見(jiàn)問(wèn)題集錦
- 分享一下Mysql常見(jiàn)的幾個(gè)錯(cuò)誤問(wèn)題及解決方法
- mysql常見(jiàn)問(wèn)題解決
- MySQL使用的常見(jiàn)問(wèn)題解決與應(yīng)用技巧匯總
相關(guān)文章
MySQL和PolarDB的相同點(diǎn)及不同點(diǎn)解讀
這篇文章主要介紹了MySQL和PolarDB的相同點(diǎn)及不同點(diǎn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03
linux下mysql數(shù)據(jù)庫(kù)單向同步配置方法分享
mysql數(shù)據(jù)庫(kù)單向同步又叫做主從復(fù)制,是通過(guò)二進(jìn)制日志文件完成的,注意:mysql 數(shù)據(jù)庫(kù)的版本,兩個(gè)數(shù)據(jù)庫(kù)版本要相同2012-06-06
MySQL數(shù)據(jù)表基本操作實(shí)例詳解
這篇文章主要介紹了MySQL數(shù)據(jù)表基本操作,結(jié)合實(shí)例形式較為詳細(xì)的分析了MySQL針對(duì)數(shù)據(jù)表的基本創(chuàng)建、表結(jié)構(gòu)查看、修改、刪除等相關(guān)操作技巧,需要的朋友可以參考下2018-06-06
Mysql 服務(wù) 1067 錯(cuò)誤 的解決方法:修改mysql可執(zhí)行文件路徑
這篇文章主要介紹了Mysql 服務(wù) 1067 錯(cuò)誤 的解決方法:修改mysql可執(zhí)行文件路徑的相關(guān)資料,需要的朋友可以參考下2017-05-05
DBA應(yīng)該知道的一些關(guān)于SQL Server跟蹤標(biāo)記的使用
本篇文章小編為大家介紹,DBA應(yīng)該知道的一些關(guān)于SQL Server跟蹤標(biāo)記的使用。需要的朋友參考下2013-04-04

