为了账号安全,请及时绑定邮箱和手机立即绑定

从 php 调用 MSSQL 存储过程

从 php 调用 MSSQL 存储过程

PHP
一只萌萌小番薯 2021-11-13 18:58:13
我们整个上午都被这件事难住了。我有一个处理一些记录的 MSSQL 存储过程。每条记录都会生成一封带有动态内容的电子邮件,这是从另一个存储过程填充的。所以第一个存储过程有一个游标,每一行都被处理导致调用另一个存储过程,它本身有一个游标可以循环。第一个存储过程没有输出参数或返回值等,而第二个使用输出参数将字段返回给第一个过程。这在 Datagrip 中运行良好。使用 PDO(或使用其他驱动程序)从 php 调用它无法完全运行。它会产生一小批记录然后停止(往往是 5、9、13 或 45 - 随着我们对不同解决方案的试验而改变)。我们已经设法让它现在使用 PDOStatement::nextRowset 运行。我们使用第一个存储过程的查询,然后使用while ( $stmt->nextRowset() ) ; 循环遍历(不存在/不需要的)行集。这有效。但是由于第一个存储的 proc 没有返回任何内容(只是 pdo 似乎想要处理某种内部结果集),这似乎非常脏且效率低下。有替代方案吗?可能是要传递给 pdo 的参数,还是存储过程中的设置?下面有一些简化的代码来展示事物是如何交互的。PHP调用脚本。<?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条经验 获得超4个赞

因为第一个存储的过程没有返回任何东西......有没有替代方法 while ( $stmt->nextRowset() ) ;

我可能是 rowcount 消息导致客户端看到空行集。添加SET NOCOUNT ON为每个存储过程的第一行。


查看完整回答
反对 回复 2021-11-13
  • 1 回答
  • 0 关注
  • 92 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号