php - PDO dblib nextRowset 不工作

标签 php sql-server pdo centos freetds

我正在将 PHP 应用程序从在 Windows 环境中运行转换为基于 Linux 的环境。

它利用 PDO 针对 Microsoft SQL Server 数据库运行存储过程。

因此,我已经安装并配置了 PHP 5.6.22、Apache、freetds 和 pdo dblib 以方便应用程序。

大多数存储过程执行都运行良好。返回多个行集的除外。

当我调用 $pdo->nextRowset() 时,我得到了这个 fatal error :

SQLSTATE[HY000]: General error: PDO_DBLIB: dbresults() returned FAIL

我能找到的唯一引用是 PHP 5.6.9 中报告的错误,该错误已修复。

但是,我在 PHP 5.6.22 中遇到了同样的问题。

有没有人知道为什么会发生这种情况以及我该如何解决?

最佳答案

您是使用 PDO::fetch 还是 PDO::fetchAll 获取数据?因为如果你使用“获取”方法并且没有到达行的末尾,PDO::nextRowset() 将会失败(我不知道为什么,它只是发生在我身上)。

所以,对我来说,强制扫描所有行 直到 PDO::fetch 返回 false,然后 PDO::nextRowset() 将正常执行。

这意味着如果行集中只有一行,则必须至少调用 PDO::fetch 两次(1 次用于检索数据,1 次返回 false)然后传递给下一个行集.

关于php - PDO dblib nextRowset 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38012890/

相关文章:

php - ^ 在 PHP 中是什么意思?

SQL - 时间序列 - 对于缺失值返回 0

PHP PDO 类连接

php - 在 PHP 中运行查询以显示在表中

php - PDO 删除查询不起作用

php - CouchDB View 可访问,但不会运行查询

php - 无法向表中插入数据

java - 通过 cmd 提示符从 PHP 执行 .jar 文件并捕获输出

SQL Server - 如何在表中查找十六进制字符

sql-server - T-Sql 声明和设置