2005-12-01 13:39:48 +00:00
|
|
|
--TEST--
|
2007-05-07 18:03:01 +00:00
|
|
|
Bug #27303 (OCIBindByName binds numeric PHP values as characters)
|
2005-12-01 13:39:48 +00:00
|
|
|
--SKIPIF--
|
2008-06-19 19:56:11 +00:00
|
|
|
<?php
|
|
|
|
if (!extension_loaded('oci8')) die ("skip no oci8 extension");
|
|
|
|
require(dirname(__FILE__)."/connect.inc");
|
2011-11-01 21:30:57 +00:00
|
|
|
// The bind buffer size edge cases seem to change each DB version.
|
|
|
|
if (preg_match('/Release 10\.2\.0\.3/', oci_server_version($c), $matches) !== 1) {
|
|
|
|
if (preg_match('/Release 11\.1\.0\.6/', oci_server_version($c), $matches) !== 1) {
|
|
|
|
if (preg_match('/Release 11\.2\.0\.3/', oci_server_version($c), $matches) !== 1) {
|
|
|
|
die("skip expected output only valid when using specific Oracle database versions");
|
|
|
|
}
|
|
|
|
}
|
2008-06-19 19:56:11 +00:00
|
|
|
}
|
|
|
|
?>
|
2005-12-01 13:39:48 +00:00
|
|
|
--FILE--
|
|
|
|
<?php
|
|
|
|
|
2011-06-10 19:16:35 +00:00
|
|
|
require(dirname(__FILE__).'/connect.inc');
|
2005-12-01 13:39:48 +00:00
|
|
|
|
2011-06-10 19:16:35 +00:00
|
|
|
$stmtarray = array(
|
|
|
|
"drop sequence myseq",
|
|
|
|
"drop table mytab",
|
|
|
|
"create sequence myseq",
|
|
|
|
"create table mytab (mydata varchar2(20), seqcol number)"
|
|
|
|
);
|
|
|
|
|
|
|
|
oci8_test_sql_execute($c, $stmtarray);
|
2005-12-01 13:39:48 +00:00
|
|
|
|
|
|
|
define('MYLIMIT', 200);
|
|
|
|
|
|
|
|
$stmt = "insert into mytab (mydata, seqcol) values ('Some data', myseq.nextval) returning seqcol into :mybv";
|
|
|
|
|
|
|
|
$stid = OCIParse($c, $stmt);
|
|
|
|
if (!$stid) { echo "Parse error"; die; }
|
|
|
|
|
2010-03-26 19:38:26 +00:00
|
|
|
$r = OCIBindByName($stid, ':MYBV', $mybv);
|
2005-12-01 13:39:48 +00:00
|
|
|
if (!$r) { echo "Bind error"; die; }
|
|
|
|
|
|
|
|
for ($i = 1; $i < MYLIMIT; $i++) {
|
|
|
|
$r = OCIExecute($stid, OCI_DEFAULT);
|
|
|
|
if (!$r) { echo "Execute error"; die; }
|
|
|
|
var_dump($mybv);
|
|
|
|
}
|
|
|
|
|
|
|
|
OCICommit($c);
|
|
|
|
|
2011-06-10 19:16:35 +00:00
|
|
|
$stmtarray = array(
|
|
|
|
"drop sequence myseq",
|
|
|
|
"drop table mytab"
|
|
|
|
);
|
2005-12-01 13:39:48 +00:00
|
|
|
|
2011-06-10 19:16:35 +00:00
|
|
|
oci8_test_sql_execute($c, $stmtarray);
|
2005-12-01 13:39:48 +00:00
|
|
|
|
|
|
|
echo "Done\n";
|
|
|
|
?>
|
2008-02-26 01:05:59 +00:00
|
|
|
--EXPECT--
|
2005-12-01 13:39:48 +00:00
|
|
|
string(1) "1"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "9"
|
2008-02-26 01:05:59 +00:00
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "2"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "3"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "4"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "5"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "6"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "7"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "8"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "9"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
|
|
|
string(1) "1"
|
2005-12-01 13:39:48 +00:00
|
|
|
Done
|