2

我们正在运行一个完全无关紧要的查询,并收到以下错误:

PDOException : SQLSTATE[24000]: Invalid cursor state: 0 [FreeTDS][SQL Server]Invalid cursor state (SQLExecute[0] at /builddir/build/BUILD/php-5.5.13/ext/pdo_odbc/odbc_stmt.c:254)

从 PHP 我们使用pdo_odbc库通过 FreeTDS 连接到 SQLServer 2008

4

1 回答 1

8

事实证明,是前面的查询导致了问题。我们正在使用:

$pdo_statement->fetch(\PDO::FETCH_ASSOC);

出来单行,但在那之后不做任何事情。这使游标保持打开状态,然后在下次执行任何查询时引发错误。对我们来说,在下一个查询之前关闭游标是前进的方向。

$pdo_statement->closeCursor();

还值得注意的是,使用fetchAll()(在前面的查询中)也是一个修复,因为这不会让游标保持打开状态。

$pdo_statement->fetchAll(\PDO::FETCH_ASSOC);
于 2014-10-16T10:28:47.613 回答