📄 pdo_012.phpt
字号:
--TEST--PDO Common: PDOStatement::setFetchMode--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\', \'Group2\')'); $SELECT = 'SELECT val, grp FROM test';$stmt = $db->query($SELECT, PDO::FETCH_NUM);var_dump($stmt->fetchAll());class Test{ function __construct($name = 'N/A') { echo __METHOD__ . "($name)\n"; }}unset($stmt);$stmt = $db->query($SELECT, PDO::FETCH_CLASS, 'Test');var_dump($stmt->fetchAll());unset($stmt);$stmt = $db->query($SELECT, PDO::FETCH_NUM);$stmt->setFetchMode(PDO::FETCH_CLASS, 'Test', array('Changed'));var_dump($stmt->fetchAll());?>--EXPECTF--array(2) { [0]=> array(2) { [0]=> string(1) "A" [1]=> string(6) "Group1" } [1]=> array(2) { [0]=> string(1) "B" [1]=> string(6) "Group2" }}Test::__construct(N/A)Test::__construct(N/A)array(2) { [0]=> object(Test)#%d (2) { ["val"]=> string(1) "A" ["grp"]=> string(6) "Group1" } [1]=> object(Test)#%d (2) { ["val"]=> string(1) "B" ["grp"]=> string(6) "Group2" }}Test::__construct(Changed)Test::__construct(Changed)array(2) { [0]=> object(Test)#%d (2) { ["val"]=> string(1) "A" ["grp"]=> string(6) "Group1" } [1]=> object(Test)#%d (2) { ["val"]=> string(1) "B" ["grp"]=> string(6) "Group2" }}--UEXPECTF--array(2) { [0]=> array(2) { [0]=> unicode(1) "A" [1]=> unicode(6) "Group1" } [1]=> array(2) { [0]=> unicode(1) "B" [1]=> unicode(6) "Group2" }}Test::__construct(N/A)Test::__construct(N/A)array(2) { [0]=> object(Test)#%d (2) { [u"val"]=> unicode(1) "A" [u"grp"]=> unicode(6) "Group1" } [1]=> object(Test)#%d (2) { [u"val"]=> unicode(1) "B" [u"grp"]=> unicode(6) "Group2" }}Test::__construct(Changed)Test::__construct(Changed)array(2) { [0]=> object(Test)#%d (2) { [u"val"]=> unicode(1) "A" [u"grp"]=> unicode(6) "Group1" } [1]=> object(Test)#%d (2) { [u"val"]=> unicode(1) "B" [u"grp"]=> unicode(6) "Group2" }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -