📄 pdo_011.phpt
字号:
--TEST--PDO Common: PDO::FETCH_FUNC and statement overloading--SKIPIF--<?php # vim:ft=phpif (!extension_loaded('pdo')) die('skip');$dir = getenv('REDIR_TEST_DIR');if (false == $dir) die('skip no driver');require_once $dir . 'pdo_test.inc';PDOTest::skip();?>--FILE--<?phpif (getenv('REDIR_TEST_DIR') === false) putenv('REDIR_TEST_DIR='.dirname(__FILE__) . '/../../pdo/tests/');require_once getenv('REDIR_TEST_DIR') . 'pdo_test.inc';$db = PDOTest::factory();$db->exec('CREATE TABLE test(id int NOT NULL PRIMARY KEY, val VARCHAR(10), grp VARCHAR(10))');$db->exec('INSERT INTO test VALUES(1, \'A\', \'Group1\')'); $db->exec('INSERT INTO test VALUES(2, \'B\', \'Group1\')'); $db->exec('INSERT INTO test VALUES(3, \'C\', \'Group2\')'); $db->exec('INSERT INTO test VALUES(4, \'D\', \'Group2\')'); class DerivedStatement extends PDOStatement{ private function __construct($name, $db) { $this->name = $name; echo __METHOD__ . "($name)\n"; } function reTrieve($id, $val) { echo __METHOD__ . "($id,$val)\n"; return array($id=>$val); }}$select1 = $db->prepare('SELECT grp, id FROM test');$select2 = $db->prepare('SELECT id, val FROM test');$derived = $db->prepare('SELECT id, val FROM test', array(PDO::ATTR_STATEMENT_CLASS=>array('DerivedStatement', array('Overloaded', $db))));class Test1{ public function __construct($id, $val) { echo __METHOD__ . "($id,$val)\n"; $this->id = $id; $this->val = $val; } static public function factory($id, $val) { echo __METHOD__ . "($id,$val)\n"; return new self($id, $val); }}function test($id,$val='N/A'){ echo __METHOD__ . "($id,$val)\n"; return array($id=>$val);}$f = new Test1(0,0);$select1->execute();var_dump($select1->fetchAll(PDO::FETCH_FUNC|PDO::FETCH_GROUP, 'test'));$select2->execute();var_dump($select2->fetchAll(PDO::FETCH_FUNC, 'test'));$select2->execute();var_dump($select2->fetchAll(PDO::FETCH_FUNC, array('Test1','factory')));$select2->execute();var_dump($select2->fetchAll(PDO::FETCH_FUNC, array($f, 'factory')));var_dump(get_class($derived));$derived->execute();var_dump($derived->fetchAll(PDO::FETCH_FUNC, array($derived, 'retrieve')));$derived->execute();var_dump($derived->fetchAll(PDO::FETCH_FUNC, array($derived, 'reTrieve')));$derived->execute();var_dump($derived->fetchAll(PDO::FETCH_FUNC, array($derived, 'RETRIEVE')));?>--EXPECTF--DerivedStatement::__construct(Overloaded)Test1::__construct(0,0)test(1,N/A)test(2,N/A)test(3,N/A)test(4,N/A)array(2) { ["Group1"]=> array(2) { [0]=> array(1) { [1]=> string(3) "N/A" } [1]=> array(1) { [2]=> string(3) "N/A" } } ["Group2"]=> array(2) { [0]=> array(1) { [3]=> string(3) "N/A" } [1]=> array(1) { [4]=> string(3) "N/A" } }}test(1,A)test(2,B)test(3,C)test(4,D)array(4) { [0]=> array(1) { [1]=> string(1) "A" } [1]=> array(1) { [2]=> string(1) "B" } [2]=> array(1) { [3]=> string(1) "C" } [3]=> array(1) { [4]=> string(1) "D" }}Test1::factory(1,A)Test1::__construct(1,A)Test1::factory(2,B)Test1::__construct(2,B)Test1::factory(3,C)Test1::__construct(3,C)Test1::factory(4,D)Test1::__construct(4,D)array(4) { [0]=> object(Test1)#%d (2) { ["id"]=> string(1) "1" ["val"]=> string(1) "A" } [1]=> object(Test1)#%d (2) { ["id"]=> string(1) "2" ["val"]=> string(1) "B" } [2]=> object(Test1)#%d (2) { ["id"]=> string(1) "3" ["val"]=> string(1) "C" } [3]=> object(Test1)#%d (2) { ["id"]=> string(1) "4" ["val"]=> string(1) "D" }}Test1::factory(1,A)Test1::__construct(1,A)Test1::factory(2,B)Test1::__construct(2,B)Test1::factory(3,C)Test1::__construct(3,C)Test1::factory(4,D)Test1::__construct(4,D)array(4) { [0]=> object(Test1)#%d (2) { ["id"]=> string(1) "1" ["val"]=> string(1) "A" } [1]=> object(Test1)#%d (2) { ["id"]=> string(1) "2" ["val"]=> string(1) "B" } [2]=> object(Test1)#%d (2) { ["id"]=> string(1) "3" ["val"]=> string(1) "C" } [3]=> object(Test1)#%d (2) { ["id"]=> string(1) "4" ["val"]=> string(1) "D" }}string(16) "DerivedStatement"DerivedStatement::reTrieve(1,A)DerivedStatement::reTrieve(2,B)DerivedStatement::reTrieve(3,C)DerivedStatement::reTrieve(4,D)array(4) { [0]=> array(1) { [1]=> string(1) "A" } [1]=> array(1) { [2]=> string(1) "B" } [2]=> array(1) { [3]=> string(1) "C" } [3]=> array(1) { [4]=> string(1) "D" }}DerivedStatement::reTrieve(1,A)DerivedStatement::reTrieve(2,B)DerivedStatement::reTrieve(3,C)DerivedStatement::reTrieve(4,D)array(4) { [0]=> array(1) { [1]=> string(1) "A" } [1]=> array(1) { [2]=> string(1) "B" } [2]=> array(1) { [3]=> string(1) "C" } [3]=> array(1) { [4]=> string(1) "D" }}DerivedStatement::reTrieve(1,A)DerivedStatement::reTrieve(2,B)DerivedStatement::reTrieve(3,C)DerivedStatement::reTrieve(4,D)array(4) { [0]=> array(1) { [1]=> string(1) "A" } [1]=> array(1) { [2]=> string(1) "B" } [2]=> array(1) { [3]=> string(1) "C" } [3]=> array(1) { [4]=> string(1) "D" }}--UEXPECTF--DerivedStatement::__construct(Overloaded)Test1::__construct(0,0)test(1,N/A)test(2,N/A)test(3,N/A)test(4,N/A)array(2) { [u"Group1"]=> array(2) { [0]=> array(1) { [1]=> unicode(3) "N/A" } [1]=> array(1) { [2]=> unicode(3) "N/A" } } [u"Group2"]=> array(2) { [0]=> array(1) { [3]=> unicode(3) "N/A" } [1]=> array(1) { [4]=> unicode(3) "N/A" } }}test(1,A)test(2,B)test(3,C)test(4,D)array(4) { [0]=> array(1) { [1]=> unicode(1) "A" } [1]=> array(1) { [2]=> unicode(1) "B" } [2]=> array(1) { [3]=> unicode(1) "C" } [3]=> array(1) { [4]=> unicode(1) "D" }}Test1::factory(1,A)Test1::__construct(1,A)Test1::factory(2,B)Test1::__construct(2,B)Test1::factory(3,C)Test1::__construct(3,C)Test1::factory(4,D)Test1::__construct(4,D)array(4) { [0]=> object(Test1)#%d (2) { [u"id"]=> unicode(1) "1" [u"val"]=> unicode(1) "A" } [1]=> object(Test1)#%d (2) { [u"id"]=> unicode(1) "2" [u"val"]=> unicode(1) "B" } [2]=> object(Test1)#%d (2) { [u"id"]=> unicode(1) "3" [u"val"]=> unicode(1) "C" } [3]=> object(Test1)#%d (2) { [u"id"]=> unicode(1) "4" [u"val"]=> unicode(1) "D" }}Test1::factory(1,A)Test1::__construct(1,A)Test1::factory(2,B)Test1::__construct(2,B)Test1::factory(3,C)Test1::__construct(3,C)Test1::factory(4,D)Test1::__construct(4,D)array(4) { [0]=> object(Test1)#%d (2) { [u"id"]=> unicode(1) "1" [u"val"]=> unicode(1) "A" } [1]=> object(Test1)#%d (2) { [u"id"]=> unicode(1) "2" [u"val"]=> unicode(1) "B" } [2]=> object(Test1)#%d (2) { [u"id"]=> unicode(1) "3" [u"val"]=> unicode(1) "C" } [3]=> object(Test1)#%d (2) { [u"id"]=> unicode(1) "4" [u"val"]=> unicode(1) "D" }}unicode(16) "DerivedStatement"DerivedStatement::reTrieve(1,A)DerivedStatement::reTrieve(2,B)DerivedStatement::reTrieve(3,C)DerivedStatement::reTrieve(4,D)array(4) { [0]=> array(1) { [1]=> unicode(1) "A" } [1]=> array(1) { [2]=> unicode(1) "B" } [2]=> array(1) { [3]=> unicode(1) "C" } [3]=> array(1) { [4]=> unicode(1) "D" }}DerivedStatement::reTrieve(1,A)DerivedStatement::reTrieve(2,B)DerivedStatement::reTrieve(3,C)DerivedStatement::reTrieve(4,D)array(4) { [0]=> array(1) { [1]=> unicode(1) "A" } [1]=> array(1) { [2]=> unicode(1) "B" } [2]=> array(1) { [3]=> unicode(1) "C" } [3]=> array(1) { [4]=> unicode(1) "D" }}DerivedStatement::reTrieve(1,A)DerivedStatement::reTrieve(2,B)DerivedStatement::reTrieve(3,C)DerivedStatement::reTrieve(4,D)array(4) { [0]=> array(1) { [1]=> unicode(1) "A" } [1]=> array(1) { [2]=> unicode(1) "B" } [2]=> array(1) { [3]=> unicode(1) "C" } [3]=> array(1) { [4]=> unicode(1) "D" }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -