123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- --TEST--
- PDO Common: Bug #65946 (pdo_sql_parser.c permanently converts values bound to strings)
- --EXTENSIONS--
- pdo
- --SKIPIF--
- <?php
- $dir = getenv('REDIR_TEST_DIR');
- if (false == $dir) die('skip no driver');
- require_once $dir . 'pdo_test.inc';
- PDOTest::skip();
- ?>
- --FILE--
- <?php
- if (getenv('REDIR_TEST_DIR') === false) putenv('REDIR_TEST_DIR='.__DIR__ . '/../../pdo/tests/');
- require_once getenv('REDIR_TEST_DIR') . 'pdo_test.inc';
- $db = PDOTest::factory();
- $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, true);
- $db->exec('CREATE TABLE test(id int)');
- $db->exec('INSERT INTO test VALUES(1)');
- switch ($db->getAttribute(PDO::ATTR_DRIVER_NAME)) {
- case 'dblib':
- $sql = 'SELECT TOP :limit * FROM test';
- break;
- case 'odbc':
- $sql = 'SELECT TOP (:limit) * FROM test';
- break;
- case 'firebird':
- $sql = 'SELECT FIRST :limit * FROM test';
- break;
- case 'oci':
- //$sql = 'SELECT * FROM test FETCH FIRST :limit ROWS ONLY'; // Oracle 12c syntax
- $sql = "select id from (select a.*, rownum rnum from (SELECT * FROM test) a where rownum <= :limit)";
- break;
- default:
- $sql = 'SELECT * FROM test LIMIT :limit';
- break;
- }
- $stmt = $db->prepare($sql);
- $stmt->bindValue('limit', 1, PDO::PARAM_INT);
- if(!($res = $stmt->execute())) var_dump($stmt->errorInfo());
- if(!($res = $stmt->execute())) var_dump($stmt->errorInfo());
- var_dump($stmt->fetchAll(PDO::FETCH_ASSOC));
- ?>
- --EXPECT--
- array(1) {
- [0]=>
- array(1) {
- ["id"]=>
- string(1) "1"
- }
- }
|