bind_number.phpt 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. --TEST--
  2. Bind with NUMBER column variants
  3. --SKIPIF--
  4. <?php
  5. if (!extension_loaded('oci8')) die("skip no oci8 extension");
  6. ?>
  7. --INI--
  8. precision = 14
  9. --FILE--
  10. <?php
  11. require(dirname(__FILE__).'/connect.inc');
  12. // Initialization
  13. $stmtarray = array(
  14. "drop table bind_number_tab",
  15. "create table bind_number_tab (
  16. id number,
  17. number_t6 number(6),
  18. float_t float,
  19. binary_float_t binary_float,
  20. binary_double_t binary_double,
  21. decimal_t decimal,
  22. integer_t integer)"
  23. );
  24. oci8_test_sql_execute($c, $stmtarray);
  25. function check_col($c, $colname, $id)
  26. {
  27. $s = oci_parse($c, "select $colname from bind_number_tab where id = :id");
  28. oci_bind_by_name($s, ":id", $id);
  29. oci_execute($s);
  30. oci_fetch_all($s, $r);
  31. var_dump($r);
  32. }
  33. // Run Test
  34. echo "Test 1 - invalid number\n";
  35. $s = oci_parse($c, "INSERT INTO bind_number_tab (id, number_t6) VALUES (1, :n1)");
  36. $n1 = "Hello";
  37. oci_bind_by_name($s, ":n1", $n1);
  38. oci_execute($s);
  39. check_col($c, "number_t6", 1);
  40. echo "\nTEST66 insert a float\n";
  41. $s = oci_parse($c, "INSERT INTO bind_number_tab (id, float_t) VALUES (66, :f1)");
  42. $f1 = 123.456;
  43. oci_bind_by_name($s, ":f1", $f1);
  44. oci_execute($s);
  45. check_col($c, 'float_t', 66);
  46. echo "\nTEST67 insert a binary float\n";
  47. $s = oci_parse($c, "INSERT INTO bind_number_tab (id, binary_float_t) VALUES (67, :f1)");
  48. $f1 = 567.456;
  49. oci_bind_by_name($s, ":f1", $f1);
  50. oci_execute($s);
  51. check_col($c, 'binary_float_t', 67);
  52. echo "\nTEST69 insert a binary double\n";
  53. $s = oci_parse($c, "INSERT INTO bind_number_tab (id, binary_double_t) VALUES (69, :f1)");
  54. $f1 = 567.456;
  55. oci_bind_by_name($s, ":f1", $f1);
  56. oci_execute($s);
  57. check_col($c, 'binary_double_t', 69);
  58. echo "\nTEST71 insert a decimal\n";
  59. $s = oci_parse($c, "INSERT INTO bind_number_tab (id, decimal_t) VALUES (71, :f1)");
  60. $f1 = 123.789;
  61. oci_bind_by_name($s, ":f1", $f1);
  62. oci_execute($s);
  63. check_col($c, 'decimal_t', 71);
  64. echo "\nTEST72 insert a decimal\n";
  65. $s = oci_parse($c, "INSERT INTO bind_number_tab (id, decimal_t) VALUES (72, :f1)");
  66. $f1 = 123.789;
  67. oci_bind_by_name($s, ":f1", $f1, -1, SQLT_NUM);
  68. oci_execute($s);
  69. check_col($c, 'decimal_t', 72);
  70. echo "\nTEST73 insert a double\n";
  71. $s = oci_parse($c, "INSERT INTO bind_number_tab (id, binary_double_t) VALUES (73, :f1)");
  72. $f1 = 483.589;
  73. oci_bind_by_name($s, ":f1", $f1);
  74. oci_execute($s);
  75. check_col($c, 'binary_double_t', 73);
  76. echo "\nTEST75 insert a INTEGER\n";
  77. $s = oci_parse($c, "INSERT INTO bind_number_tab (id, integer_t) VALUES (75, :f1)");
  78. $f1 = 589;
  79. oci_bind_by_name($s, ":f1", $f1);
  80. oci_execute($s);
  81. check_col($c, 'integer_t', 75);
  82. echo "\nTEST76 insert a INTEGER\n";
  83. $s = oci_parse($c, "INSERT INTO bind_number_tab (id, integer_t) VALUES (76, :f1)");
  84. $f1 = 42;
  85. oci_bind_by_name($s, ":f1", $f1, -1, SQLT_INT);
  86. oci_execute($s);
  87. check_col($c, 'integer_t', 76);
  88. // Clean up
  89. $stmtarray = array(
  90. "drop table bind_number_tab"
  91. );
  92. oci8_test_sql_execute($c, $stmtarray);
  93. ?>
  94. ===DONE===
  95. <?php exit(0); ?>
  96. --EXPECTF--
  97. Test 1 - invalid number
  98. Warning: oci_execute(): ORA-01722: %s in %sbind_number.php on line %d
  99. array(1) {
  100. ["NUMBER_T6"]=>
  101. array(0) {
  102. }
  103. }
  104. TEST66 insert a float
  105. array(1) {
  106. ["FLOAT_T"]=>
  107. array(1) {
  108. [0]=>
  109. string(7) "123.456"
  110. }
  111. }
  112. TEST67 insert a binary float
  113. array(1) {
  114. ["BINARY_FLOAT_T"]=>
  115. array(1) {
  116. [0]=>
  117. string(%r15|8%r) "%r(5.67455994E\+002|567.4560)%r"
  118. }
  119. }
  120. TEST69 insert a binary double
  121. array(1) {
  122. ["BINARY_DOUBLE_T"]=>
  123. array(1) {
  124. [0]=>
  125. string(%r23|16%r) "%r(5.6745600000000002E\+002|567.456000000000)%r"
  126. }
  127. }
  128. TEST71 insert a decimal
  129. array(1) {
  130. ["DECIMAL_T"]=>
  131. array(1) {
  132. [0]=>
  133. string(3) "124"
  134. }
  135. }
  136. TEST72 insert a decimal
  137. array(1) {
  138. ["DECIMAL_T"]=>
  139. array(1) {
  140. [0]=>
  141. string(1) "0"
  142. }
  143. }
  144. TEST73 insert a double
  145. array(1) {
  146. ["BINARY_DOUBLE_T"]=>
  147. array(1) {
  148. [0]=>
  149. string(%r12|16%r) "%r(4.83589E\+002|483.589000000000)%r"
  150. }
  151. }
  152. TEST75 insert a INTEGER
  153. array(1) {
  154. ["INTEGER_T"]=>
  155. array(1) {
  156. [0]=>
  157. string(3) "589"
  158. }
  159. }
  160. TEST76 insert a INTEGER
  161. array(1) {
  162. ["INTEGER_T"]=>
  163. array(1) {
  164. [0]=>
  165. string(2) "42"
  166. }
  167. }
  168. ===DONE===