第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

從 php 調(diào)用 MSSQL 存儲過程

從 php 調(diào)用 MSSQL 存儲過程

PHP
一只萌萌小番薯 2021-11-13 18:58:13
我們整個上午都被這件事難住了。我有一個處理一些記錄的 MSSQL 存儲過程。每條記錄都會生成一封帶有動態(tài)內(nèi)容的電子郵件,這是從另一個存儲過程填充的。所以第一個存儲過程有一個游標,每一行都被處理導致調(diào)用另一個存儲過程,它本身有一個游標可以循環(huán)。第一個存儲過程沒有輸出參數(shù)或返回值等,而第二個使用輸出參數(shù)將字段返回給第一個過程。這在 Datagrip 中運行良好。使用 PDO(或使用其他驅(qū)動程序)從 php 調(diào)用它無法完全運行。它會產(chǎn)生一小批記錄然后停止(往往是 5、9、13 或 45 - 隨著我們對不同解決方案的試驗而改變)。我們已經(jīng)設法讓它現(xiàn)在使用 PDOStatement::nextRowset 運行。我們使用第一個存儲過程的查詢,然后使用while ( $stmt->nextRowset() ) ; 循環(huán)遍歷(不存在/不需要的)行集。這有效。但是由于第一個存儲的 proc 沒有返回任何內(nèi)容(只是 pdo 似乎想要處理某種內(nèi)部結(jié)果集),這似乎非常臟且效率低下。有替代方案嗎?可能是要傳遞給 pdo 的參數(shù),還是存儲過程中的設置?下面有一些簡化的代碼來展示事物是如何交互的。PHP調(diào)用腳本。<?php$emailRepository = new EmailRepository(hostname, port, dbname, username, password);$ret = $emailRepository->sendRenewalEmails();class EmailRepository{    public function __construct($hostname, $port, $dbname, $username, $password)    {        $this->hostname = $hostname;        $this->port = $port;        $this->dbname = $dbname;        $this->username = $username;        $this->password = $password;        $this->connect();    }    private function connect()    {        try {            $this->db = new PDO ("sqlsrv:Server=$this->hostname,$this->port;Database=$this->dbname", $this->username, $this->password);            $this->db->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );        } catch (PDOException $e) {            var_dump("Failed to get DB handle: " . $e->getMessage());        }    }    public function sendRenewalEmails()    {      try {        $stmt = $this->db->prepare("EXEC membership_queue_renewal_emails");        $stmt->execute();        do {          echo '>';        } while($stmt->nextRowset());        return true;      } catch (Exception $e) {        echo $e->getMessage();      }    }}
查看完整描述

1 回答

?
溫溫醬

TA貢獻1752條經(jīng)驗 獲得超4個贊

因為第一個存儲的過程沒有返回任何東西......有沒有替代方法 while ( $stmt->nextRowset() ) ;

我可能是 rowcount 消息導致客戶端看到空行集。添加SET NOCOUNT ON為每個存儲過程的第一行。


查看完整回答
反對 回復 2021-11-13
  • 1 回答
  • 0 關注
  • 113 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號