summaryrefslogtreecommitdiff
path: root/ext/oci8/tests/lob_001.phpt
blob: cb94bfae1327af8427a45b16f06f629b719389f3 (plain)
ofshex dumpascii
0000 2d 2d 54 45 53 54 2d 2d 0a 6f 63 69 5f 6c 6f 62 5f 77 72 69 74 65 28 29 20 61 6e 64 20 66 72 69 --TEST--.oci_lob_write().and.fri
0020 65 6e 64 73 0a 2d 2d 53 4b 49 50 49 46 2d 2d 0a 3c 3f 70 68 70 0a 24 74 61 72 67 65 74 5f 64 62 ends.--SKIPIF--.<?php.$target_db
0040 73 20 3d 20 61 72 72 61 79 28 27 6f 72 61 63 6c 65 64 62 27 20 3d 3e 20 74 72 75 65 2c 20 27 74 s.=.array('oracledb'.=>.true,.'t
0060 69 6d 65 73 74 65 6e 27 20 3d 3e 20 66 61 6c 73 65 29 3b 20 20 2f 2f 20 74 65 73 74 20 72 75 6e imesten'.=>.false);..//.test.run
0080 73 20 6f 6e 20 74 68 65 73 65 20 44 42 73 0a 72 65 71 75 69 72 65 28 64 69 72 6e 61 6d 65 28 5f s.on.these.DBs.require(dirname(_
00a0 5f 46 49 4c 45 5f 5f 29 2e 27 2f 73 6b 69 70 69 66 2e 69 6e 63 27 29 3b 0a 3f 3e 20 0a 2d 2d 46 _FILE__).'/skipif.inc');.?>..--F
00c0 49 4c 45 2d 2d 0a 3c 3f 70 68 70 0a 09 0a 72 65 71 75 69 72 65 28 64 69 72 6e 61 6d 65 28 5f 5f ILE--.<?php...require(dirname(__
00e0 46 49 4c 45 5f 5f 29 2e 27 2f 63 6f 6e 6e 65 63 74 2e 69 6e 63 27 29 3b 0a 0a 2f 2f 20 49 6e 69 FILE__).'/connect.inc');..//.Ini
0100 74 69 61 6c 69 7a 61 74 69 6f 6e 0a 0a 24 73 74 6d 74 61 72 72 61 79 20 3d 20 61 72 72 61 79 28 tialization..$stmtarray.=.array(
0120 0a 09 22 64 72 6f 70 20 74 61 62 6c 65 20 6c 6f 62 5f 30 30 31 5f 74 61 62 22 2c 0a 09 22 63 72 .."drop.table.lob_001_tab",.."cr
0140 65 61 74 65 20 74 61 62 6c 65 20 6c 6f 62 5f 30 30 31 5f 74 61 62 20 28 69 64 20 6e 75 6d 62 65 eate.table.lob_001_tab.(id.numbe
0160 72 2c 20 62 31 20 62 6c 6f 62 29 22 2c 0a 29 3b 0a 0a 6f 63 69 38 5f 74 65 73 74 5f 73 71 6c 5f r,.b1.blob)",.);..oci8_test_sql_
0180 65 78 65 63 75 74 65 28 24 63 2c 20 24 73 74 6d 74 61 72 72 61 79 29 3b 0a 0a 65 63 68 6f 20 22 execute($c,.$stmtarray);..echo."
01a0 54 65 73 74 20 31 20 4f 43 49 5f 42 5f 42 4c 4f 42 20 62 69 6e 64 5c 6e 22 3b 0a 0a 24 73 74 61 Test.1.OCI_B_BLOB.bind\n";..$sta
01c0 74 65 6d 65 6e 74 20 3d 20 6f 63 69 5f 70 61 72 73 65 28 24 63 2c 20 22 69 6e 73 65 72 74 20 69 tement.=.oci_parse($c,."insert.i
01e0 6e 74 6f 20 6c 6f 62 5f 30 30 31 5f 74 61 62 20 28 69 64 2c 20 62 31 29 20 76 61 6c 75 65 73 20 nto.lob_001_tab.(id,.b1).values.
0200 28 31 2c 20 65 6d 70 74 79 5f 62 6c 6f 62 28 29 29 20 72 65 74 75 72 6e 69 6e 67 20 62 31 20 69 (1,.empty_blob()).returning.b1.i
0220 6e 74 6f 20 3a 76 5f 62 31 20 22 29 3b 0a 24 62 6c 6f 62 20 3d 20 6f 63 69 5f 6e 65 77 5f 64 65 nto.:v_b1.");.$blob.=.oci_new_de
0240 73 63 72 69 70 74 6f 72 28 24 63 2c 4f 43 49 5f 44 5f 4c 4f 42 29 3b 0a 76 61 72 5f 64 75 6d 70 scriptor($c,OCI_D_LOB);.var_dump
0260 28 6f 63 69 5f 62 69 6e 64 5f 62 79 5f 6e 61 6d 65 28 24 73 74 61 74 65 6d 65 6e 74 2c 20 22 3a (oci_bind_by_name($statement,.":
0280 76 5f 62 31 22 2c 20 24 62 6c 6f 62 2c 20 2d 31 2c 20 4f 43 49 5f 42 5f 42 4c 4f 42 29 29 3b 0a v_b1",.$blob,.-1,.OCI_B_BLOB));.
02a0 6f 63 69 5f 65 78 65 63 75 74 65 28 24 73 74 61 74 65 6d 65 6e 74 2c 20 4f 43 49 5f 44 45 46 41 oci_execute($statement,.OCI_DEFA
02c0 55 4c 54 29 3b 0a 76 61 72 5f 64 75 6d 70 28 24 62 6c 6f 62 29 3b 0a 0a 65 63 68 6f 20 22 54 65 ULT);.var_dump($blob);..echo."Te
02e0 73 74 20 32 5c 6e 22 3b 0a 0a 76 61 72 5f 64 75 6d 70 28 24 62 6c 6f 62 2d 3e 77 72 69 74 65 28 st.2\n";..var_dump($blob->write(
0300 22 74 65 73 74 22 29 29 3b 0a 76 61 72 5f 64 75 6d 70 28 24 62 6c 6f 62 2d 3e 74 65 6c 6c 28 29 "test"));.var_dump($blob->tell()
0320 29 3b 0a 76 61 72 5f 64 75 6d 70 28 24 62 6c 6f 62 2d 3e 73 65 65 6b 28 31 30 2c 20 4f 43 49 5f );.var_dump($blob->seek(10,.OCI_
0340 53 45 45 4b 5f 43 55 52 29 29 3b 0a 76 61 72 5f 64 75 6d 70 28 24 62 6c 6f 62 2d 3e 77 72 69 74 SEEK_CUR));.var_dump($blob->writ
0360 65 28 22 73 74 72 69 6e 67 22 29 29 3b 0a 76 61 72 5f 64 75 6d 70 28 24 62 6c 6f 62 2d 3e 66 6c e("string"));.var_dump($blob->fl
0380 75 73 68 28 29 29 3b 0a 0a 6f 63 69 5f 63 6f 6d 6d 69 74 28 24 63 29 3b 0a 0a 65 63 68 6f 20 22 ush());..oci_commit($c);..echo."
03a0 54 65 73 74 20 33 5c 6e 22 3b 0a 0a 24 73 20 3d 20 6f 63 69 5f 70 61 72 73 65 28 24 63 2c 20 22 Test.3\n";..$s.=.oci_parse($c,."
03c0 73 65 6c 65 63 74 20 62 31 20 66 72 6f 6d 20 6c 6f 62 5f 30 30 31 5f 74 61 62 20 77 68 65 72 65 select.b1.from.lob_001_tab.where
03e0 20 69 64 20 3d 20 31 22 29 3b 0a 6f 63 69 5f 65 78 65 63 75 74 65 28 24 73 29 3b 0a 76 61 72 5f .id.=.1");.oci_execute($s);.var_
0400 64 75 6d 70 28 6f 63 69 5f 66 65 74 63 68 5f 61 72 72 61 79 28 24 73 2c 20 4f 43 49 5f 52 45 54 dump(oci_fetch_array($s,.OCI_RET
0420 55 52 4e 5f 4c 4f 42 53 29 29 3b 0a 0a 65 63 68 6f 20 22 54 65 73 74 20 34 20 53 51 4c 54 5f 42 URN_LOBS));..echo."Test.4.SQLT_B
0440 4c 4f 42 20 28 61 6e 20 61 6c 69 61 73 20 66 6f 72 20 4f 43 49 5f 42 5f 42 4c 4f 42 29 20 62 69 LOB.(an.alias.for.OCI_B_BLOB).bi
0460 6e 64 5c 6e 22 3b 0a 0a 24 73 74 61 74 65 6d 65 6e 74 20 3d 20 6f 63 69 5f 70 61 72 73 65 28 24 nd\n";..$statement.=.oci_parse($
0480 63 2c 20 22 69 6e 73 65 72 74 20 69 6e 74 6f 20 6c 6f 62 5f 30 30 31 5f 74 61 62 20 28 69 64 2c c,."insert.into.lob_001_tab.(id,
04a0 20 62 31 29 20 76 61 6c 75 65 73 20 28 32 2c 20 65 6d 70 74 79 5f 62 6c 6f 62 28 29 29 20 72 65 .b1).values.(2,.empty_blob()).re
04c0 74 75 72 6e 69 6e 67 20 62 31 20 69 6e 74 6f 20 3a 76 5f 62 31 20 22 29 3b 0a 24 62 6c 6f 62 20 turning.b1.into.:v_b1.");.$blob.
04e0 3d 20 6f 63 69 5f 6e 65 77 5f 64 65 73 63 72 69 70 74 6f 72 28 24 63 2c 4f 43 49 5f 44 5f 4c 4f =.oci_new_descriptor($c,OCI_D_LO
0500 42 29 3b 0a 76 61 72 5f 64 75 6d 70 28 6f 63 69 5f 62 69 6e 64 5f 62 79 5f 6e 61 6d 65 28 24 73 B);.var_dump(oci_bind_by_name($s
0520 74 61 74 65 6d 65 6e 74 2c 20 22 3a 76 5f 62 31 22 2c 20 24 62 6c 6f 62 2c 20 2d 31 2c 20 53 51 tatement,.":v_b1",.$blob,.-1,.SQ
0540 4c 54 5f 42 4c 4f 42 29 29 3b 0a 6f 63 69 5f 65 78 65 63 75 74 65 28 24 73 74 61 74 65 6d 65 6e LT_BLOB));.oci_execute($statemen
0560 74 2c 20 4f 43 49 5f 44 45 46 41 55 4c 54 29 3b 0a 76 61 72 5f 64 75 6d 70 28 24 62 6c 6f 62 2d t,.OCI_DEFAULT);.var_dump($blob-
0580 3e 77 72 69 74 65 28 22 74 65 73 74 20 72 6f 77 20 32 22 29 29 3b 0a 0a 24 73 20 3d 20 6f 63 69 >write("test.row.2"));..$s.=.oci
05a0 5f 70 61 72 73 65 28 24 63 2c 20 22 73 65 6c 65 63 74 20 62 31 20 66 72 6f 6d 20 6c 6f 62 5f 30 _parse($c,."select.b1.from.lob_0
05c0 30 31 5f 74 61 62 20 77 68 65 72 65 20 69 64 20 3d 20 32 22 29 3b 0a 6f 63 69 5f 65 78 65 63 75 01_tab.where.id.=.2");.oci_execu
05e0 74 65 28 24 73 29 3b 0a 76 61 72 5f 64 75 6d 70 28 6f 63 69 5f 66 65 74 63 68 5f 61 72 72 61 79 te($s);.var_dump(oci_fetch_array
0600 28 24 73 2c 20 4f 43 49 5f 52 45 54 55 52 4e 5f 4c 4f 42 53 29 29 3b 0a 0a 2f 2f 20 43 6c 65 61 ($s,.OCI_RETURN_LOBS));..//.Clea
0620 6e 75 70 0a 0a 24 73 74 6d 74 61 72 72 61 79 20 3d 20 61 72 72 61 79 28 0a 09 22 64 72 6f 70 20 nup..$stmtarray.=.array(.."drop.
0640 74 61 62 6c 65 20 6c 6f 62 5f 30 30 31 5f 74 61 62 22 0a 29 3b 0a 0a 6f 63 69 38 5f 74 65 73 74 table.lob_001_tab".);..oci8_test
0660 5f 73 71 6c 5f 65 78 65 63 75 74 65 28 24 63 2c 20 24 73 74 6d 74 61 72 72 61 79 29 3b 0a 0a 3f _sql_execute($c,.$stmtarray);..?
0680 3e 0a 3d 3d 3d 44 4f 4e 45 3d 3d 3d 0a 3c 3f 70 68 70 20 65 78 69 74 28 30 29 3b 20 3f 3e 0a 2d >.===DONE===.<?php.exit(0);.?>.-
06a0 2d 45 58 50 45 43 54 46 2d 2d 0a 54 65 73 74 20 31 20 4f 43 49 5f 42 5f 42 4c 4f 42 20 62 69 6e -EXPECTF--.Test.1.OCI_B_BLOB.bin
06c0 64 0a 62 6f 6f 6c 28 74 72 75 65 29 0a 6f 62 6a 65 63 74 28 4f 43 49 2d 4c 6f 62 29 23 25 64 20 d.bool(true).object(OCI-Lob)#%d.
06e0 28 31 29 20 7b 0a 20 20 5b 22 64 65 73 63 72 69 70 74 6f 72 22 5d 3d 3e 0a 20 20 72 65 73 6f 75 (1).{...["descriptor"]=>...resou
0700 72 63 65 28 25 64 29 20 6f 66 20 74 79 70 65 20 28 6f 63 69 38 20 64 65 73 63 72 69 70 74 6f 72 rce(%d).of.type.(oci8.descriptor
0720 29 0a 7d 0a 54 65 73 74 20 32 0a 69 6e 74 28 34 29 0a 69 6e 74 28 34 29 0a 62 6f 6f 6c 28 74 72 ).}.Test.2.int(4).int(4).bool(tr
0740 75 65 29 0a 69 6e 74 28 36 29 0a 62 6f 6f 6c 28 66 61 6c 73 65 29 0a 54 65 73 74 20 33 0a 61 72 ue).int(6).bool(false).Test.3.ar
0760 72 61 79 28 32 29 20 7b 0a 20 20 5b 30 5d 3d 3e 0a 20 20 73 74 72 69 6e 67 28 32 30 29 20 22 74 ray(2).{...[0]=>...string(20)."t
0780 65 73 74 00 00 00 00 00 00 00 00 00 00 73 74 72 69 6e 67 22 0a 20 20 5b 22 42 31 22 5d 3d 3e 0a est..........string"...["B1"]=>.
07a0 20 20 73 74 72 69 6e 67 28 32 30 29 20 22 74 65 73 74 00 00 00 00 00 00 00 00 00 00 73 74 72 69 ..string(20)."test..........stri
07c0 6e 67 22 0a 7d 0a 54 65 73 74 20 34 20 53 51 4c 54 5f 42 4c 4f 42 20 28 61 6e 20 61 6c 69 61 73 ng".}.Test.4.SQLT_BLOB.(an.alias
07e0 20 66 6f 72 20 4f 43 49 5f 42 5f 42 4c 4f 42 29 20 62 69 6e 64 0a 62 6f 6f 6c 28 74 72 75 65 29 .for.OCI_B_BLOB).bind.bool(true)
0800 0a 69 6e 74 28 31 30 29 0a 61 72 72 61 79 28 32 29 20 7b 0a 20 20 5b 30 5d 3d 3e 0a 20 20 73 74 .int(10).array(2).{...[0]=>...st
0820 72 69 6e 67 28 31 30 29 20 22 74 65 73 74 20 72 6f 77 20 32 22 0a 20 20 5b 22 42 31 22 5d 3d 3e ring(10)."test.row.2"...["B1"]=>
0840 0a 20 20 73 74 72 69 6e 67 28 31 30 29 20 22 74 65 73 74 20 72 6f 77 20 32 22 0a 7d 0a 3d 3d 3d ...string(10)."test.row.2".}.===
0860 44 4f 4e 45 3d 3d 3d 0a DONE===.