mirror of
https://github.com/php/php-src.git
synced 2025-08-16 05:58:45 +02:00

TL;DR When suing libmysqlclient, ints are fetched as strings, so the strict comparison was failing
68 lines
1.7 KiB
PHP
68 lines
1.7 KiB
PHP
--TEST--
|
|
MySQL PDO Parser custom syntax
|
|
--EXTENSIONS--
|
|
pdo_mysql
|
|
--SKIPIF--
|
|
<?php
|
|
require_once __DIR__ . '/inc/mysql_pdo_test.inc';
|
|
MySQLPDOTest::skip();
|
|
?>
|
|
--FILE--
|
|
<?php
|
|
require_once __DIR__ . '/inc/mysql_pdo_test.inc';
|
|
$db = MySQLPDOTest::factory();
|
|
|
|
$table = 'pdo_mysql_parser';
|
|
|
|
$db->exec("DROP TABLE IF EXISTS {$table}");
|
|
$db->exec("CREATE TABLE {$table} (`a``?` int NOT NULL)");
|
|
$db->exec("INSERT INTO {$table} VALUES (1)");
|
|
|
|
// No parameters
|
|
$queries = [
|
|
"SELECT * FROM {$table}",
|
|
"SELECT * FROM {$table} -- ?",
|
|
"SELECT * FROM {$table} # ?",
|
|
"SELECT * FROM {$table} /* ? */",
|
|
];
|
|
|
|
foreach ($queries as $k => $query) {
|
|
$stmt = $db->prepare($query);
|
|
$stmt->execute();
|
|
var_dump($query, $stmt->fetch(PDO::FETCH_NUM) == [0 => 1]);
|
|
}
|
|
|
|
// One parameter
|
|
$queries = [
|
|
"SELECT * FROM {$table} WHERE 1 = ?",
|
|
"SELECT * FROM {$table} WHERE 1 = --?",
|
|
"SELECT * FROM {$table} WHERE \"?\" IN (?, '?')",
|
|
"SELECT * FROM {$table} WHERE `a``?` = ?",
|
|
];
|
|
|
|
foreach ($queries as $k => $query) {
|
|
$stmt = $db->prepare($query);
|
|
$stmt->execute([1]);
|
|
var_dump($query, $stmt->fetch(PDO::FETCH_NUM) == [0 => 1]);
|
|
}
|
|
|
|
$db->exec("DROP TABLE pdo_mysql_parser");
|
|
|
|
?>
|
|
--EXPECT--
|
|
string(30) "SELECT * FROM pdo_mysql_parser"
|
|
bool(true)
|
|
string(35) "SELECT * FROM pdo_mysql_parser -- ?"
|
|
bool(true)
|
|
string(34) "SELECT * FROM pdo_mysql_parser # ?"
|
|
bool(true)
|
|
string(38) "SELECT * FROM pdo_mysql_parser /* ? */"
|
|
bool(true)
|
|
string(42) "SELECT * FROM pdo_mysql_parser WHERE 1 = ?"
|
|
bool(true)
|
|
string(44) "SELECT * FROM pdo_mysql_parser WHERE 1 = --?"
|
|
bool(true)
|
|
string(52) "SELECT * FROM pdo_mysql_parser WHERE "?" IN (?, '?')"
|
|
bool(true)
|
|
string(47) "SELECT * FROM pdo_mysql_parser WHERE `a``?` = ?"
|
|
bool(true)
|