亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mysql多次調(diào)用存儲(chǔ)過程的問題

 更新時(shí)間:2011年05月07日 23:59:15   作者:  
這個(gè)問題也困擾了我很長時(shí)間,準(zhǔn)確的說正是因?yàn)樗拇鎯?chǔ)過程無法在同一連接中2次或者多次執(zhí)行,我大幅修該了程序架構(gòu),全部題換成了sql,但是畢竟sql無法執(zhí)行有相當(dāng)邏輯的代碼,最總讓我從新測試以求尋找解決之道。
問題是這樣的,在直接使用mysql c api構(gòu)建應(yīng)用的時(shí)候,一個(gè)連接只能執(zhí)行一次存儲(chǔ)過程,不管怎樣free再次利用這個(gè)連接的時(shí)候就會(huì)出現(xiàn)不能執(zhí)行qurry的提示,我想,這么大型的軟件 不會(huì)存在這樣的基礎(chǔ)性問題吧,畢竟大多數(shù)的adodb都是基于c api的,難道所有的軟件都無法進(jìn)行連接緩存?

別說,接觸到這類問題的人還真不多,大多數(shù)的連接池都寫好了,誰會(huì)去直接構(gòu)建連接進(jìn)行操作呢,所以baidu google基本都沒有結(jié)果,今天回頭來解決這個(gè)問題,突然就有了突破,找到了一篇文章《對(duì)Mysql的C API調(diào)用存儲(chǔ)過程的問題及解決方法分析》,正是我的問題。
作者分析的挺復(fù)雜了,其實(shí)我們一般只用mysql_query、mysql_use_result等幾個(gè)函數(shù),問題的癥結(jié)在于當(dāng)執(zhí)行一個(gè)存儲(chǔ)過程的時(shí)候, 數(shù)據(jù)庫返回的是多個(gè)數(shù)據(jù)集合,即使只有一個(gè)數(shù)據(jù)集合,他也會(huì)有一個(gè)空集合用于結(jié)束一次回話,作者罵他變態(tài),其實(shí)不然,可能作者考慮到的只是一般的請(qǐng) 求,mysql是給所有用戶使用的,說不能真有變態(tài)的人把圖片文件等等直接保存在mysql字段里面,那么回復(fù)就不可能一次完成,需要多此網(wǎng)絡(luò)交互,那么 所有的交互肯定需要一個(gè)結(jié)束符號(hào),并且存儲(chǔ)過程本來就可以返回多個(gè)數(shù)據(jù)集合,如果他在c pai中只做一個(gè)結(jié)果己處理就允許下一次全新的請(qǐng)求,那么對(duì)于同一連接,在mysql服務(wù)斷其實(shí)還有沒有發(fā)送完成的數(shù)據(jù),這個(gè)時(shí)候他安全的做法就是不接受 任何新的請(qǐng)求,直到數(shù)據(jù)發(fā)送完全,或者連接關(guān)閉,不然,mysql協(xié)議解析就會(huì)出現(xiàn)問題,下次發(fā)送就會(huì)出現(xiàn)黏包或者丟包,所以他的做法是完全正確的,即使 只有一個(gè)結(jié)果集合,也需要當(dāng)前會(huì)話內(nèi)的通訊(比如mysql_next_result)確認(rèn)完畢,然后結(jié)束本次請(qǐng)求,這個(gè)時(shí)候服務(wù)端其實(shí)沒有數(shù)據(jù)了,但是 這個(gè)過程是不能省略的,然后在不關(guān)閉連接的情況下就可以進(jìn)行全新的請(qǐng)求了。
所以總結(jié)起來就是:使用存儲(chǔ)過程的時(shí)候一定要循環(huán)執(zhí)行,把所有的結(jié)果集合都取到,直到為空,這個(gè)時(shí)候當(dāng)前數(shù)據(jù)庫連接才可以安全歸還回去,下面是demo。
復(fù)制代碼 代碼如下:

MYSQL_RES *conn;
MYSQL_RES *res;
MYSQL_ROW row;
conn = 連接池.Get("xxxx");

mysql_query(conn, "call qt()");

res = mysql_use_result(conn);
while ((row = mysql_fetch_row(res))) {
do main thins; //這次是對(duì)于第一個(gè)數(shù)據(jù)集的處理
}
mysql_free_result(res);
while ((res = mysql_next_result(conn)) != NULL) {
do some thing; //循環(huán)處理其他的數(shù)據(jù)集
mysql_free_result(res);
}
連接池.Free(conn)

經(jīng)過上面的循環(huán)讀取就能夠保證一條連接會(huì)干凈地歸還到連接池,當(dāng)然有的連接池可能已經(jīng)把后面一個(gè)循環(huán)放在連接池中處理了,解釋說把剩余的數(shù)據(jù)集全部取過來然后釋放,這樣比如在php等里面使用mysql的連接池的時(shí)候就沒有感受到上面說的問題。

相關(guān)文章

  • MAC上Mysql忘記Root密碼或權(quán)限錯(cuò)誤的快速解決方案

    MAC上Mysql忘記Root密碼或權(quán)限錯(cuò)誤的快速解決方案

    這篇文章主要介紹了MAC上Mysql忘記Root密碼或權(quán)限錯(cuò)誤的快速解決方案的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • Python MySQL進(jìn)行數(shù)據(jù)庫表變更和查詢

    Python MySQL進(jìn)行數(shù)據(jù)庫表變更和查詢

    這篇文章主要介紹了Python MySQL進(jìn)行數(shù)據(jù)庫表變更和查詢的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • SQL Server 2005 安裝遇到的錯(cuò)誤提示和解決方法

    SQL Server 2005 安裝遇到的錯(cuò)誤提示和解決方法

    在安裝SQL Server 2005時(shí)有時(shí)會(huì)出現(xiàn)意想不到的問題,如IIS,性能計(jì)數(shù)器,OWC11,無法配置外圍應(yīng)用的問題,下面筆者分享一下在安裝SQL Server 2005時(shí)常見問題解決方法
    2014-01-01
  • MySQL主從狀態(tài)檢查的實(shí)現(xiàn)

    MySQL主從狀態(tài)檢查的實(shí)現(xiàn)

    這篇文章主要介紹了MySQL主從狀態(tài)檢查的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • RedHat6.5安裝MySQL5.7教程詳解

    RedHat6.5安裝MySQL5.7教程詳解

    這篇文章主要為大家詳細(xì)介紹了RedHat6.5下MySQL5.7的安裝教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • mysql limit 分頁的用法及注意要點(diǎn)

    mysql limit 分頁的用法及注意要點(diǎn)

    limit在mysql語句中使用的頻率非常高,一般分頁查詢都會(huì)使用到limit語句,本文章向碼農(nóng)們介紹mysql limit 分頁的用法與注意事項(xiàng),需要的朋友可以參考下
    2016-12-12
  • MySQL 如何設(shè)計(jì)統(tǒng)計(jì)數(shù)據(jù)表

    MySQL 如何設(shè)計(jì)統(tǒng)計(jì)數(shù)據(jù)表

    有些時(shí)候,改進(jìn)數(shù)據(jù)表查詢性能的最佳方式是在同一張數(shù)據(jù)表中冗余一些繼承的數(shù)據(jù)。然而,有些時(shí)候需要新建完全獨(dú)立的統(tǒng)計(jì)或緩存數(shù)據(jù)表,尤其是在需要反復(fù)查詢的需求情況下。如果業(yè)務(wù)允許一些時(shí)間上的誤差的話,那么這種方式會(huì)更好。
    2021-06-06
  • Mysql數(shù)據(jù)庫面試必備之三大log介紹

    Mysql數(shù)據(jù)庫面試必備之三大log介紹

    大家好,本篇文章主要講的是Mysql數(shù)據(jù)庫面試必備之三大log介紹,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下
    2021-12-12
  • 如何用cmd連接Mysql數(shù)據(jù)庫

    如何用cmd連接Mysql數(shù)據(jù)庫

    如何用cmd連接Mysql數(shù)據(jù)庫,需要的朋友可以參考一下
    2013-03-03
  • MySQL數(shù)據(jù)庫設(shè)計(jì)之利用Python操作Schema方法詳解

    MySQL數(shù)據(jù)庫設(shè)計(jì)之利用Python操作Schema方法詳解

    這篇文章主要介紹了MySQL數(shù)據(jù)庫設(shè)計(jì)之利用Python操作Schema方法詳解,還是比較不錯(cuò)的,這里分享給大家,供需要的朋友參考。
    2017-11-11

最新評(píng)論