MySQL 一次執(zhí)行多條語句的實(shí)現(xiàn)及常見問題
更新時(shí)間:2009年08月15日 02:04:26 作者:
通常情況MySQL出于安全考慮不允許一次執(zhí)行多條語句(但也不報(bào)錯(cuò),很讓人郁悶)。
MySQL是支持在單個(gè)查詢字符串中指定多語句執(zhí)行的,使用方法是給鏈接指定參數(shù):
//鏈接時(shí)設(shè)定
mysql_real_connect( ..., CLIENT_MULTI_STATEMENTS );
//或者
//中途指定
mysql_set_server_option( mysql, MYSQL_OPTION_MULTI_STATEMENTS_ON ); //mysql是連接的名稱
當(dāng)使用執(zhí)行多語句功能后,一定要讀完整個(gè)resault集,否則會(huì)出現(xiàn)錯(cuò)誤:Commands out of sync; you can't run this command now
官方推薦的執(zhí)行語句是這樣的:
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語句,也一樣得讀完整個(gè)resault集并釋放,最小化的寫法:
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是連接的名稱
當(dāng)使用執(zhí)行多語句功能后,一定要讀完整個(gè)resault集,否則會(huì)出現(xiàn)錯(cuò)誤:Commands out of sync; you can't run this command now
官方推薦的執(zhí)行語句是這樣的:
復(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語句,也一樣得讀完整個(gè)resault集并釋放,最小化的寫法:
復(fù)制代碼 代碼如下:
do
{
result = mysql_store_result( mysql );
mysql_free_result(result);
}while( !mysql_next_result( mysql ) );
相關(guān)文章
如何保護(hù)MySQL中重要數(shù)據(jù)的方法
在日常的工作中,保護(hù)數(shù)據(jù)免受未授權(quán)用戶的侵犯是系統(tǒng)管理員特別關(guān)心的問題。如果你目前用的是MySQL,就可以使用一些方便的功能來保護(hù)系統(tǒng),來大大減少機(jī)密數(shù)據(jù)被未授權(quán)用戶訪問的風(fēng)險(xiǎn)2011-10-10Mysql數(shù)據(jù)庫時(shí)間查詢舉例詳解
在項(xiàng)目開發(fā)中,一些業(yè)務(wù)表字段經(jīng)常使用日期和時(shí)間類型,而且后續(xù)還會(huì)牽涉到這類字段的查詢,下面這篇文章主要給大家介紹了關(guān)于Mysql數(shù)據(jù)庫時(shí)間查詢的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05一文帶你永久擺脫Mysql時(shí)區(qū)錯(cuò)誤問題(idea數(shù)據(jù)庫可視化插件配置)
在MySQL啟動(dòng)時(shí)會(huì)檢查當(dāng)前系統(tǒng)的時(shí)區(qū)并根據(jù)系統(tǒng)時(shí)區(qū)設(shè)置全局參數(shù)system_time_zone的值,下面這篇文章主要給大家介紹了關(guān)于如何永久擺脫Mysql時(shí)區(qū)錯(cuò)誤問題(idea數(shù)據(jù)庫可視化插件配置)的相關(guān)資料,需要的朋友可以參考下2022-08-08mysql表的內(nèi)連和外連實(shí)戰(zhàn)記錄
在開發(fā)中我們的業(yè)務(wù)需求有時(shí)候是復(fù)雜的,多張表聯(lián)合查詢的時(shí)候是有多種方式的,面對(duì)不同的需求,靈活使用不同的表連接方式,這篇文章主要給大家介紹了關(guān)于mysql表內(nèi)連和外連的相關(guān)資料,需要的朋友可以參考下2024-01-01