Skip to main content

PHP KB: No records found when using SQL variables and PDO parameters

Issue

The PDO class for PHP throws an error when running queries against SQL Server and returning multiple results sets.


Cause

Without the benefit of the details around the implementation of SQL Server or the SQLSRV PDO driver, there's no way to know what's causing this issue.  However, the anecdotal evidence points to the the lack of support in the SQLSRV driver for SQL Server's ability to return multiple datasets.

One of the errors that has been encountered reported a question mark (?) placeholder in each place where an SQL variable was in the script that was passed to the PDO::prepare() method call.  This was taken to mean that the method was perceiving each SQL variable as a parameter that it should be looking for in the parameters array passed in the PDOStatement::execute() method.  In other words, it was interpreting SQL parameters (variables) as PDO parameters (?).

Ultimately, this issue is likely to come down to the use of the table data type or temporary tables in the query.


Solution

Use the NO COUNT flag as follows, and at the top of the script.

SET NO COUNT ON


Environment

SQL Server version 2008
PHP version 5.3 Windows
PDO driver version SQLSRV 2.0
Apache version 2.4 Windows


Details

While it’s difficult to know for sure without extensive testing, the situation seems to be when using SQL variables (@VARIABLENAME) in conjunction with PDO parameters (using the ? placeholder).  There is also some expectation that the issue exists when a query returns multiple results sets.

The sample query below is an example of a case that will present this issue.

DECLARE @variableA INT
DECLARE @variableB TABLE (otherTableID INT)

SET @someID = ?

INSERT into @variableB (otherTableID)
SELECT otherTableID FROM sourceTable WHERE sourceTableID = @someID


SELECT *
FROM yetAnotherTable
WHERE yetAnotherTableID = findMeID

This query would run fine when run directly on SQL Server.  However, when used as the query in a PDO call, like the following, it fails.

$Query = $Conn->prepare("/* Query form example. */");
$Query->execute(array("someIDValue"));

$data = $Query->fetchAll(PDO::FETCH_ASSOC);

The following three (3) lines present the solution, which are really just the first two (2) lines with the NOCOUNT flag set as the first line.

DECLARE @variableA INT
DECLARE @variableB TABLE (otherTableID INT)

SET @someID = ?

INSERT into @variableB (otherTableID)
SELECT otherTableID FROM sourceTable WHERE sourceTableID = @someID


SELECT *
FROM yetAnotherTable
WHERE yetAnotherTableID = findMeID

Comments

Popular posts from this blog

PHP built-in webserver and IPv6 addresses

Though it's difficult to confirm around the Web, it appears as though the IP address scheme the built-in PHP server uses depends on the host name that's provided.  If a fully-qualified domain name (FQDN) is used, such as server.domain.tld, then the built-in server will be listening for IPv6 based requests.  If the server is started with an IPv4 address identified as the host, then it will naturally listen for IPv4 based requests. The closest to anything official around the Web was a comment in the PHP docs that only seeded this conclusion, at best.  But here it is in any case. Built-in web server http://php.net/manual/en/features.commandline.webserver.php#120449 Ultimately, the following answer from Stack Overflow held the "universal" solution.  Thank you dew010. Running PHP 5.4 built-in web server outside localhost http://stackoverflow.com/a/8377378/2487485 Start your development server like: php -S 0.0.0.0:8989

HP webOS interface kudos

UPDATED 06/07/2013 Pandora no-longer makes the webOS version of its player available. While quite obviously a piece rooted in opinion, a subtle nod is offered to Palm for the excellent interface work it did with webOS .  Since it’s initial release with Sprint in June 2009, Palm quickly slipped into relative oblivion.  With the recent purchase of the company by HP coupled with new product releases set for the summer, webOS may become relevant once again.  If so, then perhaps a whole new lot of users will come to appreciate the consideration that was taken with the webOS user interface (UI). An example is the popular webOS application for the even more popular Pandora Internet radio service.  And as it turns out, the company has a collection of screen captures for the various mobile platforms that have native applications for the service.  This happens to double as a quick way to compare the interface elements of other platforms by using the same applic...

Allow Windows authentication using SQL Server driver with DBeaver

DBeaver will allow Microsoft Windows single sign on access when connecting to Microsoft SQL Server using the SQL Server driver (rather than jTDS ).  From the driver properties settings, set the integratedSecurity flag to true . Open the Connection configuration panel and choose the Driver properties section. Set the integratedSecurity flag to true . A subtle, but important step is to not provide username and password credentials to the connection.