Edit report at http://bugs.php.net/bug.php?id=53960&edit=1
ID: 53960
User updated by: contato at andersonfraga dot net
Reported by: contato at andersonfraga dot net
Summary: "Invalid parameter number" for multiple params
equals in query
Status: Bogus
Type: Bug
Package: PDO related
Operating System: Windows
PHP Version: 5.3.5
Block user comment: N
Private report: N
New Comment:
Anyway...
I think it should work, right?
'Even more because' it works in 5.2.14..
Previous Comments:
------------------------------------------------------------------------
[2011-05-10 10:03:11] [email protected]
SQL - 2x hash_1:
AND (NOME_CLIENTE LIKE :hash_1
OR ENDERECO_CLIENTE LIKE :hash_1)
PHP bind - 1x hash_1, 1x hash_2:
$statement->execute(Array(
':hash_1' => '%Anderson%',
':hash_2' => 0,
------------------------------------------------------------------------
[2011-02-08 17:27:49] contato at andersonfraga dot net
Description:
------------
This error is occurring when I use the same parameter several times in
the query.
In PHP 5.2.14, using Gentoo, it works perfectly. Already in versions
5.3.0 and 5.3.3 (using Windows on both), returns an exception.
Bug or 'feature'?
Test script:
---------------
<?php
try {
$dbh = new PDO('mysql:/*irrelevant*/', Array(
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_EMULATE_PREPARES => false,
));
$select = "SELECT * FROM PR_CLIENTE
WHERE DELETADO = 'N'
AND (NOME_CLIENTE LIKE :hash_1
OR ENDERECO_CLIENTE LIKE :hash_1)
ORDER BY ID_CLIENTE DESC
LIMIT :hash_2;";
$statement = $dbh->prepare($select);
$statement->execute(Array(
':hash_1' => '%Anderson%',
':hash_2' => 0,
));
$fetch = $statement->fetchAll(PDO::FETCH_ASSOC);
print_r($fetch);
}
catch(PDOException $e) {
print_r($e->getMessage());
}
?>
Expected result:
----------------
Array
(
[0] => Array
(
[ID_CLIENTE] => 29
(...)
)
)
Actual result:
--------------
SQLSTATE[HY093]: Invalid parameter number
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/bug.php?id=53960&edit=1