pdo_012.phpt 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. --TEST--
  2. PDO Common: PDOStatement::setFetchMode
  3. --SKIPIF--
  4. <?php # vim:ft=php
  5. if (!extension_loaded('pdo')) die('skip');
  6. $dir = getenv('REDIR_TEST_DIR');
  7. if (false == $dir) die('skip no driver');
  8. require_once $dir . 'pdo_test.inc';
  9. PDOTest::skip();
  10. ?>
  11. --FILE--
  12. <?php
  13. if (getenv('REDIR_TEST_DIR') === false) putenv('REDIR_TEST_DIR='.dirname(__FILE__) . '/../../pdo/tests/');
  14. require_once getenv('REDIR_TEST_DIR') . 'pdo_test.inc';
  15. $db = PDOTest::factory();
  16. $db->exec('CREATE TABLE test(id int NOT NULL PRIMARY KEY, val VARCHAR(10), grp VARCHAR(10))');
  17. $db->exec('INSERT INTO test VALUES(1, \'A\', \'Group1\')');
  18. $db->exec('INSERT INTO test VALUES(2, \'B\', \'Group2\')');
  19. $SELECT = 'SELECT val, grp FROM test';
  20. $stmt = $db->query($SELECT, PDO::FETCH_NUM);
  21. var_dump($stmt->fetchAll());
  22. class Test
  23. {
  24. function __construct($name = 'N/A')
  25. {
  26. echo __METHOD__ . "($name)\n";
  27. }
  28. }
  29. unset($stmt);
  30. $stmt = $db->query($SELECT, PDO::FETCH_CLASS, 'Test');
  31. var_dump($stmt->fetchAll());
  32. unset($stmt);
  33. $stmt = $db->query($SELECT, PDO::FETCH_NUM);
  34. $stmt->setFetchMode(PDO::FETCH_CLASS, 'Test', array('Changed'));
  35. var_dump($stmt->fetchAll());
  36. ?>
  37. --EXPECTF--
  38. array(2) {
  39. [0]=>
  40. array(2) {
  41. [0]=>
  42. string(1) "A"
  43. [1]=>
  44. string(6) "Group1"
  45. }
  46. [1]=>
  47. array(2) {
  48. [0]=>
  49. string(1) "B"
  50. [1]=>
  51. string(6) "Group2"
  52. }
  53. }
  54. Test::__construct(N/A)
  55. Test::__construct(N/A)
  56. array(2) {
  57. [0]=>
  58. object(Test)#%d (2) {
  59. ["val"]=>
  60. string(1) "A"
  61. ["grp"]=>
  62. string(6) "Group1"
  63. }
  64. [1]=>
  65. object(Test)#%d (2) {
  66. ["val"]=>
  67. string(1) "B"
  68. ["grp"]=>
  69. string(6) "Group2"
  70. }
  71. }
  72. Test::__construct(Changed)
  73. Test::__construct(Changed)
  74. array(2) {
  75. [0]=>
  76. object(Test)#%d (2) {
  77. ["val"]=>
  78. string(1) "A"
  79. ["grp"]=>
  80. string(6) "Group1"
  81. }
  82. [1]=>
  83. object(Test)#%d (2) {
  84. ["val"]=>
  85. string(1) "B"
  86. ["grp"]=>
  87. string(6) "Group2"
  88. }
  89. }