php-src/ext/oci8/tests/bug27303_2.phpt
Antony Dovgal d99f05f1a2 add _not yet 100% complete_ Unicode support
collections, statements and BLOBs seem to be working ok
though there are still some things to be done in order to make oci_bind_array_by_name() work with U-strings

Notes:
- in Unicode mode OCI8 always speaks to Oracle server using UTF-16, so all the conversions are done by the client lib.
This is why character set parameter of oci_connect() and NLS_LANG are ignored in U-mode.

- BLOBs and CLOBs behave quite differently in U-mode.
Reading data from a CLOB would result in Unicode string, while BLOBs would return binary string.
Also, all LOB utilities work with _bytes_ when BLOB is used and _characters_ when it's CLOB.
It's not that obvious, but it does make a lot of sense to me.
2006-11-10 16:56:19 +00:00

454 lines
7.5 KiB
PHP

--TEST--
bug #27303 (OCIBindByName binds numeric PHP values as characters)
--SKIPIF--
<?php if (!extension_loaded('oci8')) die("skip no oci8 extension"); ?>
--FILE--
<?php
require dirname(__FILE__).'/connect.inc';
$create_st = array();
$create_st[] = "drop sequence myseq";
$create_st[] = "drop table mytab";
$create_st[] = "create sequence myseq";
$create_st[] = "create table mytab (mydata varchar2(20), seqcol number)";
foreach ($create_st as $statement) {
$stmt = oci_parse($c, $statement);
oci_execute($stmt);
}
define('MYLIMIT', 200);
define('INITMYBV', 11);
$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; }
$mybv = INITMYBV; // Uncomment this for the 2nd test only
$r = OCIBindByName($stid, ':MYBV', $mybv /*, 5 */); // Uncomment this for the 3rd test only
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);
$drop_st = array();
$drop_st[] = "drop sequence myseq";
$drop_st[] = "drop table mytab";
foreach ($create_st as $statement) {
$stmt = oci_parse($c, $statement);
oci_execute($stmt);
}
echo "Done\n";
?>
--EXPECTF--
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"
string(2) "10"
string(2) "11"
string(2) "12"
string(2) "13"
string(2) "14"
string(2) "15"
string(2) "16"
string(2) "17"
string(2) "18"
string(2) "19"
string(2) "20"
string(2) "21"
string(2) "22"
string(2) "23"
string(2) "24"
string(2) "25"
string(2) "26"
string(2) "27"
string(2) "28"
string(2) "29"
string(2) "30"
string(2) "31"
string(2) "32"
string(2) "33"
string(2) "34"
string(2) "35"
string(2) "36"
string(2) "37"
string(2) "38"
string(2) "39"
string(2) "40"
string(2) "41"
string(2) "42"
string(2) "43"
string(2) "44"
string(2) "45"
string(2) "46"
string(2) "47"
string(2) "48"
string(2) "49"
string(2) "50"
string(2) "51"
string(2) "52"
string(2) "53"
string(2) "54"
string(2) "55"
string(2) "56"
string(2) "57"
string(2) "58"
string(2) "59"
string(2) "60"
string(2) "61"
string(2) "62"
string(2) "63"
string(2) "64"
string(2) "65"
string(2) "66"
string(2) "67"
string(2) "68"
string(2) "69"
string(2) "70"
string(2) "71"
string(2) "72"
string(2) "73"
string(2) "74"
string(2) "75"
string(2) "76"
string(2) "77"
string(2) "78"
string(2) "79"
string(2) "80"
string(2) "81"
string(2) "82"
string(2) "83"
string(2) "84"
string(2) "85"
string(2) "86"
string(2) "87"
string(2) "88"
string(2) "89"
string(2) "90"
string(2) "91"
string(2) "92"
string(2) "93"
string(2) "94"
string(2) "95"
string(2) "96"
string(2) "97"
string(2) "98"
string(2) "99"
string(3) "100"
string(3) "101"
string(3) "102"
string(3) "103"
string(3) "104"
string(3) "105"
string(3) "106"
string(3) "107"
string(3) "108"
string(3) "109"
string(3) "110"
string(3) "111"
string(3) "112"
string(3) "113"
string(3) "114"
string(3) "115"
string(3) "116"
string(3) "117"
string(3) "118"
string(3) "119"
string(3) "120"
string(3) "121"
string(3) "122"
string(3) "123"
string(3) "124"
string(3) "125"
string(3) "126"
string(3) "127"
string(3) "128"
string(3) "129"
string(3) "130"
string(3) "131"
string(3) "132"
string(3) "133"
string(3) "134"
string(3) "135"
string(3) "136"
string(3) "137"
string(3) "138"
string(3) "139"
string(3) "140"
string(3) "141"
string(3) "142"
string(3) "143"
string(3) "144"
string(3) "145"
string(3) "146"
string(3) "147"
string(3) "148"
string(3) "149"
string(3) "150"
string(3) "151"
string(3) "152"
string(3) "153"
string(3) "154"
string(3) "155"
string(3) "156"
string(3) "157"
string(3) "158"
string(3) "159"
string(3) "160"
string(3) "161"
string(3) "162"
string(3) "163"
string(3) "164"
string(3) "165"
string(3) "166"
string(3) "167"
string(3) "168"
string(3) "169"
string(3) "170"
string(3) "171"
string(3) "172"
string(3) "173"
string(3) "174"
string(3) "175"
string(3) "176"
string(3) "177"
string(3) "178"
string(3) "179"
string(3) "180"
string(3) "181"
string(3) "182"
string(3) "183"
string(3) "184"
string(3) "185"
string(3) "186"
string(3) "187"
string(3) "188"
string(3) "189"
string(3) "190"
string(3) "191"
string(3) "192"
string(3) "193"
string(3) "194"
string(3) "195"
string(3) "196"
string(3) "197"
string(3) "198"
string(3) "199"
Done
--UEXPECTF--
unicode(1) "1"
unicode(1) "2"
unicode(1) "3"
unicode(1) "4"
unicode(1) "5"
unicode(1) "6"
unicode(1) "7"
unicode(1) "8"
unicode(1) "9"
unicode(2) "10"
unicode(2) "11"
unicode(2) "12"
unicode(2) "13"
unicode(2) "14"
unicode(2) "15"
unicode(2) "16"
unicode(2) "17"
unicode(2) "18"
unicode(2) "19"
unicode(2) "20"
unicode(2) "21"
unicode(2) "22"
unicode(2) "23"
unicode(2) "24"
unicode(2) "25"
unicode(2) "26"
unicode(2) "27"
unicode(2) "28"
unicode(2) "29"
unicode(2) "30"
unicode(2) "31"
unicode(2) "32"
unicode(2) "33"
unicode(2) "34"
unicode(2) "35"
unicode(2) "36"
unicode(2) "37"
unicode(2) "38"
unicode(2) "39"
unicode(2) "40"
unicode(2) "41"
unicode(2) "42"
unicode(2) "43"
unicode(2) "44"
unicode(2) "45"
unicode(2) "46"
unicode(2) "47"
unicode(2) "48"
unicode(2) "49"
unicode(2) "50"
unicode(2) "51"
unicode(2) "52"
unicode(2) "53"
unicode(2) "54"
unicode(2) "55"
unicode(2) "56"
unicode(2) "57"
unicode(2) "58"
unicode(2) "59"
unicode(2) "60"
unicode(2) "61"
unicode(2) "62"
unicode(2) "63"
unicode(2) "64"
unicode(2) "65"
unicode(2) "66"
unicode(2) "67"
unicode(2) "68"
unicode(2) "69"
unicode(2) "70"
unicode(2) "71"
unicode(2) "72"
unicode(2) "73"
unicode(2) "74"
unicode(2) "75"
unicode(2) "76"
unicode(2) "77"
unicode(2) "78"
unicode(2) "79"
unicode(2) "80"
unicode(2) "81"
unicode(2) "82"
unicode(2) "83"
unicode(2) "84"
unicode(2) "85"
unicode(2) "86"
unicode(2) "87"
unicode(2) "88"
unicode(2) "89"
unicode(2) "90"
unicode(2) "91"
unicode(2) "92"
unicode(2) "93"
unicode(2) "94"
unicode(2) "95"
unicode(2) "96"
unicode(2) "97"
unicode(2) "98"
unicode(2) "99"
unicode(3) "100"
unicode(3) "101"
unicode(3) "102"
unicode(3) "103"
unicode(3) "104"
unicode(3) "105"
unicode(3) "106"
unicode(3) "107"
unicode(3) "108"
unicode(3) "109"
unicode(3) "110"
unicode(3) "111"
unicode(3) "112"
unicode(3) "113"
unicode(3) "114"
unicode(3) "115"
unicode(3) "116"
unicode(3) "117"
unicode(3) "118"
unicode(3) "119"
unicode(3) "120"
unicode(3) "121"
unicode(3) "122"
unicode(3) "123"
unicode(3) "124"
unicode(3) "125"
unicode(3) "126"
unicode(3) "127"
unicode(3) "128"
unicode(3) "129"
unicode(3) "130"
unicode(3) "131"
unicode(3) "132"
unicode(3) "133"
unicode(3) "134"
unicode(3) "135"
unicode(3) "136"
unicode(3) "137"
unicode(3) "138"
unicode(3) "139"
unicode(3) "140"
unicode(3) "141"
unicode(3) "142"
unicode(3) "143"
unicode(3) "144"
unicode(3) "145"
unicode(3) "146"
unicode(3) "147"
unicode(3) "148"
unicode(3) "149"
unicode(3) "150"
unicode(3) "151"
unicode(3) "152"
unicode(3) "153"
unicode(3) "154"
unicode(3) "155"
unicode(3) "156"
unicode(3) "157"
unicode(3) "158"
unicode(3) "159"
unicode(3) "160"
unicode(3) "161"
unicode(3) "162"
unicode(3) "163"
unicode(3) "164"
unicode(3) "165"
unicode(3) "166"
unicode(3) "167"
unicode(3) "168"
unicode(3) "169"
unicode(3) "170"
unicode(3) "171"
unicode(3) "172"
unicode(3) "173"
unicode(3) "174"
unicode(3) "175"
unicode(3) "176"
unicode(3) "177"
unicode(3) "178"
unicode(3) "179"
unicode(3) "180"
unicode(3) "181"
unicode(3) "182"
unicode(3) "183"
unicode(3) "184"
unicode(3) "185"
unicode(3) "186"
unicode(3) "187"
unicode(3) "188"
unicode(3) "189"
unicode(3) "190"
unicode(3) "191"
unicode(3) "192"
unicode(3) "193"
unicode(3) "194"
unicode(3) "195"
unicode(3) "196"
unicode(3) "197"
unicode(3) "198"
unicode(3) "199"
Done