《Mysql應(yīng)用MySQL 一次執(zhí)行多條語(yǔ)句的實(shí)現(xiàn)及常見(jiàn)問(wèn)題》要點(diǎn):
本文介紹了Mysql應(yīng)用MySQL 一次執(zhí)行多條語(yǔ)句的實(shí)現(xiàn)及常見(jiàn)問(wèn)題,希望對(duì)您有用。如果有疑問(wèn),可以聯(lián)系我們。
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 ) );
轉(zhuǎn)載請(qǐng)注明本頁(yè)網(wǎng)址:
http://www.snjht.com/jiaocheng/3818.html