pdo_006.phpt 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. --TEST--
  2. PDO Common: PDO::FETCH_GROUP
  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))');
  17. $db->exec("INSERT INTO test VALUES(1, 'A')");
  18. $db->exec("INSERT INTO test VALUES(2, 'A')");
  19. $db->exec("INSERT INTO test VALUES(3, 'C')");
  20. $stmt = $db->prepare('SELECT val, id from test');
  21. $stmt->execute();
  22. var_dump($stmt->fetchAll(PDO::FETCH_NUM|PDO::FETCH_GROUP));
  23. $stmt->execute();
  24. var_dump($stmt->fetchAll(PDO::FETCH_ASSOC|PDO::FETCH_GROUP));
  25. ?>
  26. --EXPECT--
  27. array(2) {
  28. ["A"]=>
  29. array(2) {
  30. [0]=>
  31. array(1) {
  32. [0]=>
  33. string(1) "1"
  34. }
  35. [1]=>
  36. array(1) {
  37. [0]=>
  38. string(1) "2"
  39. }
  40. }
  41. ["C"]=>
  42. array(1) {
  43. [0]=>
  44. array(1) {
  45. [0]=>
  46. string(1) "3"
  47. }
  48. }
  49. }
  50. array(2) {
  51. ["A"]=>
  52. array(2) {
  53. [0]=>
  54. array(1) {
  55. ["id"]=>
  56. string(1) "1"
  57. }
  58. [1]=>
  59. array(1) {
  60. ["id"]=>
  61. string(1) "2"
  62. }
  63. }
  64. ["C"]=>
  65. array(1) {
  66. [0]=>
  67. array(1) {
  68. ["id"]=>
  69. string(1) "3"
  70. }
  71. }
  72. }