php執(zhí)行多個存儲過程的方法【基于thinkPHP】
本文實例講述了php執(zhí)行多個存儲過程的方法。分享給大家供大家參考,具體如下:
從以前的使用原生代碼來看,只需要將結(jié)果集關(guān)閉即可,即
$this -> queryID -> close();
使用mysqli方式,修改DbMysqli.class.php,將query函數(shù)改為:
public function query($str) {
$this -> initConnect(false);
if (!$this -> _linkID) {
return false;
}
$this -> queryStr = $str;
//釋放前次的查詢結(jié)果
if ($this -> queryID)
$this -> free();
N('db_query', 1);
// 記錄開始執(zhí)行時間
G('queryStartTime');
$this -> queryID = $this -> _linkID -> query($str);
// 對存儲過程改進
$ret = array();
$this -> debug();
if (false === $this -> queryID) {
$this -> error();
return false;
} else {
$this -> numRows = $this -> queryID -> num_rows;
$this -> numCols = $this -> queryID -> field_count;
$ret = $this -> getAll();
}
//主要將這段移動了一下,關(guān)閉結(jié)果集
if ($this -> _linkID -> more_results()) {
while (($res = $this -> _linkID -> next_result()) != NULL) {
$this -> queryID -> close();
}
}
return $ret ;
}
下面就可以調(diào)用多個存儲過程,或許執(zhí)行其他SQL操作,可以直接使用M函數(shù)
在使用thinkphp的時候發(fā)現(xiàn)執(zhí)行多個存儲過程只能執(zhí)行第一個,看了一下源碼Driver/Db/DbMysql.class,已經(jīng)對存儲過程進行了一定處理,但是不知道為什么運行不了。
用原生代碼解決了問題(下面是部分代碼):
$db = new mysqli(C("DB_HOST"), C("DB_USER"), C("DB_PWD"), C("DB_NAME"));
if (mysqli_connect_errno())
throw_exception(mysqli_connect_error());
$t2 = microtime(true);
echo "數(shù)據(jù)庫連接用時:" . (($t2 - $t1)) . "s <br />";
$arr = array();
// 1st Query
$procedure = "call p1()";
$result = $db->query($procedure);
if ($result) {
// Cycle through results
while ($row = $result->fetch_object()) {
//添加到對象數(shù)組
$arr[] = $row;
}
// 這里是最重要的,需要將游標(biāo)移動下一個結(jié)果集
$result->close();
$db->next_result();
}
$procedure = "call p2()";
$result = $db->query($procedure);
if ($result) {
// Cycle through results
while ($row = $result->fetch_object()) {
//添加到對象數(shù)組
$arr[] = $row;
}
// 這里是最重要的,需要將游標(biāo)移動下一個結(jié)果集
$result->close();
$db->next_result();
}
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《smarty模板入門基礎(chǔ)教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對大家基于ThinkPHP框架的PHP程序設(shè)計有所幫助。
相關(guān)文章
php設(shè)計模式之模板模式實例分析【星際爭霸游戲案例】
這篇文章主要介紹了php設(shè)計模式之模板模式,基于星際爭霸游戲案例形式分析了php模板模式相關(guān)原理與使用技巧,需要的朋友可以參考下2020-03-03
基于Swoole實現(xiàn)PHP與websocket聊天室
本文利用Swoole來實現(xiàn)PHP+websocket的聊天室,過程介紹的很詳細,對聊天室的開發(fā)很有幫助,有需要的可以參考學(xué)習(xí)。2016-08-08
php寫一個函數(shù),實現(xiàn)掃描并打印出自定目錄下(含子目錄)所有jpg文件名
下面小編就為大家?guī)硪黄猵hp寫一個函數(shù),實現(xiàn)掃描并打印出自定目錄下(含子目錄)所有jpg文件名。2017-05-05
windows下apache搭建php開發(fā)環(huán)境
本文詳細介紹了在Windows2003下使用Apache2.2.21/PHP5.3.5/Mysql5.5.19/phpMyAdmin3.4.9搭建php開發(fā)環(huán)境,本文介紹的非常詳細,需要的朋友快來學(xué)習(xí)吧2015-08-08
ThinkPHP V2.2說明文檔沒有說明的那些事實例小結(jié)
這篇文章主要介紹了ThinkPHP V2.2說明文檔沒有說明的那些事,實例分析了ThinkPHP中常用的技巧,需要的朋友可以參考下2015-07-07

