thinkphp呼叫sqlserver儲存過程返回多個結果集
阿新 • • 發佈:2020-01-10
首先安裝擴充套件
windows
分為兩個步驟
- 找到對應自己PHP版本的pdo擴充套件,下載解壓出來,並且在php.ini裡面啟用擴充套件,需要注意的問題是php版本以及是否為安全版本
- 下載 ODBC Driver https://docs.microsoft.com/zh-cn/sql/connect/odbc/download-odbc-driver-for-sql-server?view=sql-server-2017,這個沒啥注意的,你是啥系統就下載啥安裝包就行
linux 和 windows差不多,安裝擴充套件的話直接可以用pecl
當你成功載入了可以在phpinfo()裡面看到,當然了,如果你安裝擴充套件這些都有諸多問題都話,~你可真拉稀。
thinkphp操作sqlsrv儲存過程
我使用的tp版本是5.0和操作多個數據庫,希望能對你有所幫助
配置config檔案
// 賬號資料庫 'UserDBConn' => [ 'type' => 'sqlsrv',// 伺服器地址 'hostname' => '139.129.1.1',// 資料庫名 'database' => 'DB3',// 使用者名稱 'username' => 'xxxx',// 密碼 'password' => 'tt123!@#',// 埠 'hostport' => '5188' ],// 金幣資料庫 'ScoreDBConn' => [ 'type' => 'sqlsrv',// 資料庫名 'database' => 'DB2',// 記錄資料庫 'RecordDBConn' => [ 'type' => 'sqlsrv',// 資料庫名 'database' => 'DB1',
修改thinkphp/library/think/Model.php
在末尾追加
/** * @param $DbconnName */ protected function Dbconn($DbconnName){ try{ $conn = Db::connect($DbconnName); }catch (\InvalidArgumentException $e){ echo '連線異常'; die; } return $conn; }
新增模型
Agent.php
查詢和增刪改都可以呼叫query,如果你沒有想要獲取的結果集的話可以呼叫execute()。
query()有一個弊端,如果你的繫結引數的形式(非引數繫結)是直接寫進sql的話,他有可能會判斷你這個不是一個儲存過程;
具體實現請檢視thinkphp/library/think/db/Connection.php:368行,當然也不會有結果集返回。
你也可以用呼叫procedure(),這個方法呼叫的話就一定會返回結果集。
起初我就是這個問題,並沒有採用繫結引數的形式提交,直接寫sql,就獲取不到結果集,後來我在我的sql提行裡面加入了SET NOCOUNT ON;,才能勉強拿到返回,在文章最後我給出了我最開始獲取的結果集的方案例子,但是真的拉稀,你們可以看看,不要吐槽。
class Agent extends Model { public $Dbname = 'UserDBConn'; public function GetIndirectAgentList($agentId,$strAccount,$strSuperior,$iPageIndex,$pagesize) { $conn = $this->Dbconn($this->Dbname); try{ $TotalCount = 0; $res = $conn::query('exec [dbo].[Agent_GetAgentList] :agentId,:strAccount,:strSuperior,:iPageIndex,:pagesize,:TotalCount',[ 'agentId' => $agentId,'strAccount' => [$strAccount,PDO::PARAM_STR],'strSuperior' => [$strSuperior,'iPageIndex' => [$iPageIndex,PDO::PARAM_INT],'pagesize' => [$pagesize,'TotalCount' => [$TotalCount,PDO::PARAM_INPUT_OUTPUT],]); }catch (PDOException $e) { return false; } return $res; } }
最初的Agent.php
很顯然 這裡並不會獲取到@AgentID 以及 @TotalCount;他只會返回Agent_GetAgentList的結果集
public function GetIndirectAgentList($agentId,$pagesize) { $conn = $this->Dbconn($this->Dbname); try{ $res = $conn->query(' SET NOCOUNT ON; declare @AgentID int; declare @TotalCount int; exec [dbo].[Agent_GetAgentList] '.$agentId.',\''.$strAccount.'\',\''.$strSuperior.'\','.$iPageIndex.','.$pagesize.',@TotalCount output; select @AgentID as AgentID,@TotalCount as TotalCount '); }catch (PDOException $e) { return false; } return $res; }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。