pdo_024.phpt 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. --TEST--
  2. PDO Common: assert that bindParam does not modify parameter
  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. switch ($db->getAttribute(PDO::ATTR_DRIVER_NAME)) {
  17. case 'dblib':
  18. // environment settings can influence how the table is created if specifics are missing
  19. // https://msdn.microsoft.com/en-us/library/ms174979.aspx#Nullability Rules Within a Table Definition
  20. $sql = 'create table test (id int, name varchar(10) null)';
  21. break;
  22. default:
  23. $sql = 'create table test (id int, name varchar(10))';
  24. break;
  25. }
  26. $db->exec($sql);
  27. $stmt = $db->prepare('insert into test (id, name) values(0, :name)');
  28. $name = NULL;
  29. $before_bind = $name;
  30. $stmt->bindParam(':name', $name, PDO::PARAM_NULL);
  31. if ($name !== $before_bind) {
  32. echo "bind: fail\n";
  33. } else {
  34. echo "bind: success\n";
  35. }
  36. var_dump($stmt->execute());
  37. var_dump($db->query('select name from test where id=0')->fetchColumn());
  38. ?>
  39. --EXPECT--
  40. bind: success
  41. bool(true)
  42. NULL