PHP調(diào)用MySQL的存儲(chǔ)過程的實(shí)現(xiàn)代碼
更新時(shí)間:2008年08月12日 12:57:28 作者:
MySQL好像從5.0開始才引入存儲(chǔ)過程,反正以前做應(yīng)用的時(shí)候從沒碰過,不過現(xiàn)在因?yàn)橹饕鲀?nèi)部系統(tǒng)
MySQL好像從5.0開始才引入存儲(chǔ)過程,反正以前做應(yīng)用的時(shí)候從沒碰過,不過現(xiàn)在因?yàn)橹饕鲀?nèi)部系統(tǒng),所以很多應(yīng)用都用到了存儲(chǔ)過程,當(dāng)然前臺(tái)有時(shí)候也需要調(diào)用MySQL存儲(chǔ)過程,PHP的MySQL Lib好像支持的不是很好,不過我搜索了些資料,雖然不多,但是還是嘗試的使用了,現(xiàn)在介紹一下方法,以便用到的朋友不用再頭疼。
lMySQL擴(kuò)展也是支持存儲(chǔ)過程的,不過只支持無(wú)返回結(jié)果的存儲(chǔ)過程,如果該存儲(chǔ)過程存在輸出,這個(gè)調(diào)用就會(huì)拋出一個(gè)錯(cuò)誤,具體錯(cuò)誤忘記了。調(diào)用方式很簡(jiǎn)單:
$rs = mysql_query("call func('str')", $conn);
這個(gè)如果有返回結(jié)果,比如返回字符串,就會(huì)報(bào)錯(cuò),我現(xiàn)在找到的解決方法是使用MySQLi擴(kuò)展:
$rs = mysqli_query("call func('str')", $conn);
這樣$rs就作為一個(gè)普通的MySQL Result來使用了,非常方便。
在調(diào)用存儲(chǔ)過程的時(shí)候,可能還會(huì)碰到一個(gè)問題,那就是可能會(huì)順序調(diào)用多個(gè)存儲(chǔ)過程,這樣同樣會(huì)報(bào)錯(cuò),解決方法就是在調(diào)用一個(gè)存儲(chǔ)過程并處理完成后,手動(dòng)關(guān)閉MySQL鏈接,然后再次connect,再調(diào)用另一個(gè)存儲(chǔ)過程再處理,需要調(diào)用多少個(gè)存儲(chǔ)過程,就重新連接多少次。
因?yàn)槲也皇呛芰私釳ySQL擴(kuò)展,以上純屬經(jīng)驗(yàn)總結(jié),如果有哪位高手知道來龍去脈,歡迎指點(diǎn)。
lMySQL擴(kuò)展也是支持存儲(chǔ)過程的,不過只支持無(wú)返回結(jié)果的存儲(chǔ)過程,如果該存儲(chǔ)過程存在輸出,這個(gè)調(diào)用就會(huì)拋出一個(gè)錯(cuò)誤,具體錯(cuò)誤忘記了。調(diào)用方式很簡(jiǎn)單:
$rs = mysql_query("call func('str')", $conn);
這個(gè)如果有返回結(jié)果,比如返回字符串,就會(huì)報(bào)錯(cuò),我現(xiàn)在找到的解決方法是使用MySQLi擴(kuò)展:
$rs = mysqli_query("call func('str')", $conn);
這樣$rs就作為一個(gè)普通的MySQL Result來使用了,非常方便。
在調(diào)用存儲(chǔ)過程的時(shí)候,可能還會(huì)碰到一個(gè)問題,那就是可能會(huì)順序調(diào)用多個(gè)存儲(chǔ)過程,這樣同樣會(huì)報(bào)錯(cuò),解決方法就是在調(diào)用一個(gè)存儲(chǔ)過程并處理完成后,手動(dòng)關(guān)閉MySQL鏈接,然后再次connect,再調(diào)用另一個(gè)存儲(chǔ)過程再處理,需要調(diào)用多少個(gè)存儲(chǔ)過程,就重新連接多少次。
因?yàn)槲也皇呛芰私釳ySQL擴(kuò)展,以上純屬經(jīng)驗(yàn)總結(jié),如果有哪位高手知道來龍去脈,歡迎指點(diǎn)。
您可能感興趣的文章:
- PHP的PDO預(yù)處理語(yǔ)句與存儲(chǔ)過程
- PHP基于PDO調(diào)用sqlserver存儲(chǔ)過程通用方法【基于Yii框架】
- PHP使用PDO調(diào)用mssql存儲(chǔ)過程的方法示例
- 基于Php mysql存儲(chǔ)過程的詳解
- PHP調(diào)用MySQL存儲(chǔ)過程并返回值的方法
- php調(diào)用mysql存儲(chǔ)過程
- php調(diào)用mysql存儲(chǔ)過程實(shí)例分析
- php調(diào)用MySQL存儲(chǔ)過程的方法集合(推薦)
- PHP5中使用PDO連接數(shù)據(jù)庫(kù)的方法
- php中mysql連接方式PDO使用詳解
- PHP實(shí)現(xiàn)PDO操作mysql存儲(chǔ)過程示例
相關(guān)文章
PHP開發(fā)之歸檔格式phar文件概念與用法詳解【創(chuàng)建,使用,解包還原提取】
這篇文章主要介紹了PHP開發(fā)之歸檔格式phar文件概念與用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了歸檔格式phar文件創(chuàng)建,使用,解包還原提取等概念及操作實(shí)現(xiàn)方法,需要的朋友可以參考下2017-11-11
redirect_uri參數(shù)錯(cuò)誤的解決方法(必看)
下面小編就為大家?guī)硪黄猺edirect_uri參數(shù)錯(cuò)誤的解決方法(必看)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02
php基于mcrypt_encrypt和mcrypt_decrypt實(shí)現(xiàn)字符串加密解密的方法
這篇文章主要介紹了php基于mcrypt_encrypt和mcrypt_decrypt實(shí)現(xiàn)字符串加密解密的方法,結(jié)合實(shí)例形式分析了mcrypt_encrypt和mcrypt_decrypt函數(shù)進(jìn)行加密、解密的相關(guān)使用技巧,需要的朋友可以參考下2016-07-07
在PHP中利用wsdl創(chuàng)建標(biāo)準(zhǔn)webservice的實(shí)現(xiàn)代碼
網(wǎng)上有現(xiàn)成的nusoap,我沒使用,如果使用了,我可能就不知道PHP是怎么創(chuàng)建webservice的了2011-12-12
PHP中使用數(shù)組指針函數(shù)操作數(shù)組示例
這篇文章主要介紹了PHP中使用數(shù)組指針函數(shù)操作數(shù)組示例,本文講解了current()、key()、next()、prev()、end()、reset()等數(shù)組指針函數(shù),需要的朋友可以參考下2014-11-11
PHP連接SQLServer2005的實(shí)現(xiàn)方法(附ntwdblib.dll下載)
為了php連接sql2005 ,我在網(wǎng)絡(luò)上找了一大堆資料在我的csdn博客中.晚上3:05分時(shí)候終于搞定了2012-07-07

