⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pdo_011.phpt

📁 PHP v6.0 For Linux 运行环境:Win9X/ WinME/ WinNT/ Win2K/ WinXP
💻 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 + -