php IHDR w Q )Ba pHYs sRGB gAMA a IDATxMk\U s&uo,mD )Xw+e?tw.oWp;QHZnw`gaiJ9̟灙a=nl[ ʨ G;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ y H@E7j 1j+OFRg}ܫ;@Ea~ j`u'o> j- $_q?qS XzG'ay
files >> /opt/php-7.0.1/ext/pdo_firebird/tests/ |
files >> //opt/php-7.0.1/ext/pdo_firebird/tests/bug_53280.phpt |
--TEST-- PDO_Firebird: bug 53280 segfaults if query column count is less than param count --SKIPIF-- <?php extension_loaded("pdo_firebird") or die("skip"); ?> <?php function_exists("ibase_query") or die("skip"); ?> --FILE-- <?php require("testdb.inc"); $dbh = new PDO("firebird:dbname=$test_base",$user,$password) or die; $value = '2'; @$dbh->exec('DROP TABLE testz'); $dbh->exec('CREATE TABLE testz(A VARCHAR(30), B VARCHAR(30), C VARCHAR(30))'); $dbh->exec("INSERT INTO testz VALUES ('A', 'B', 'C')"); $dbh->commit(); $stmt1 = "SELECT B FROM testz WHERE A = ? AND B = ?"; $stmt2 = "SELECT B, C FROM testz WHERE A = ? AND B = ?"; $stmth2 = $dbh->prepare($stmt2); $stmth2->execute(array('A', 'B')); $rows = $stmth2->fetchAll(); // <------ OK var_dump($rows); $stmth1 = $dbh->prepare($stmt1); $stmth1->execute(array('A', 'B')); $rows = $stmth1->fetchAll(); // <------- segfault var_dump($rows); $dbh->commit(); unset($stmth1); unset($stmth2); $dbh->exec('DROP TABLE testz'); unset($stmt); unset($dbh); ?> --EXPECT-- array(1) { [0]=> array(4) { ["B"]=> string(1) "B" [0]=> string(1) "B" ["C"]=> string(1) "C" [1]=> string(1) "C" } } array(1) { [0]=> array(2) { ["B"]=> string(1) "B" [0]=> string(1) "B" } }y~or5J={Eeu磝Qk ᯘG{?+]ן?wM3X^歌>{7پK>on\jy Rg/=fOroNVv~Y+ NGuÝHWyw[eQʨSb> >}Gmx[o[<{Ϯ_qFvM IENDB`