3 V4.22 15 Apr 2004 (c) 2000-2004 John Lim. All rights reserved.
\r
4 Released under both BSD license and Lesser GPL library license.
\r
5 Whenever there is any discrepancy between the two licenses,
\r
6 the BSD license will take precedence.
\r
8 Latest version is available at http://php.weblogs.com/
\r
10 Portable version of oci8 driver, to make it more similar to other database drivers.
\r
11 The main differences are
\r
13 1. that the OCI_ASSOC names are in lowercase instead of uppercase.
\r
14 2. bind variables are mapped using ? instead of :<bindvar>
\r
16 Should some emulation of RecordCount() be implemented?
\r
20 include_once(ADODB_DIR.'/drivers/adodb-oci8.inc.php');
\r
22 class ADODB_oci8po extends ADODB_oci8 {
\r
23 var $databaseType = 'oci8po';
\r
24 var $dataProvider = 'oci8';
\r
25 var $metaColumnsSQL = "select lower(cname),coltype,width, SCALE, PRECISION, NULLS, DEFAULTVAL from col where tname='%s' order by colno"; //changed by smondino@users.sourceforge. net
\r
26 var $metaTablesSQL = "select lower(table_name),table_type from cat where table_type in ('TABLE','VIEW')";
\r
28 function ADODB_oci8po()
\r
30 $this->ADODB_oci8();
\r
33 function Param($name)
\r
38 function Prepare($sql,$cursor=false)
\r
40 $sqlarr = explode('?',$sql);
\r
42 for ($i = 1, $max = sizeof($sqlarr); $i < $max; $i++) {
\r
43 $sql .= ':'.($i-1) . $sqlarr[$i];
\r
45 return ADODB_oci8::Prepare($sql,$cursor);
\r
48 // emulate handling of parameters ? ?, replacing with :bind0 :bind1
\r
49 function _query($sql,$inputarr)
\r
51 if (is_array($inputarr)) {
\r
53 if (is_array($sql)) {
\r
54 foreach($inputarr as $v) {
\r
55 $arr['bind'.$i++] = $v;
\r
58 $sqlarr = explode('?',$sql);
\r
60 foreach($inputarr as $k => $v) {
\r
61 $sql .= ":$k" . $sqlarr[++$i];
\r
65 return ADODB_oci8::_query($sql,$inputarr);
\r
69 /*--------------------------------------------------------------------------------------
\r
70 Class Name: Recordset
\r
71 --------------------------------------------------------------------------------------*/
\r
73 class ADORecordset_oci8po extends ADORecordset_oci8 {
\r
75 var $databaseType = 'oci8po';
\r
77 function ADORecordset_oci8po($queryID,$mode=false)
\r
79 $this->ADORecordset_oci8($queryID,$mode);
\r
82 function Fields($colname)
\r
84 if ($this->fetchMode & OCI_ASSOC) return $this->fields[$colname];
\r
87 $this->bind = array();
\r
88 for ($i=0; $i < $this->_numOfFields; $i++) {
\r
89 $o = $this->FetchField($i);
\r
90 $this->bind[strtoupper($o->name)] = $i;
\r
93 return $this->fields[$this->bind[strtoupper($colname)]];
\r
96 // lowercase field names...
\r
97 function &_FetchField($fieldOffset = -1)
\r
99 $fld = new ADOFieldObject;
\r
101 $fld->name = strtolower(OCIcolumnname($this->_queryID, $fieldOffset));
\r
102 $fld->type = OCIcolumntype($this->_queryID, $fieldOffset);
\r
103 $fld->max_length = OCIcolumnsize($this->_queryID, $fieldOffset);
\r
104 if ($fld->type == 'NUMBER') {
\r
105 //$p = OCIColumnPrecision($this->_queryID, $fieldOffset);
\r
106 $sc = OCIColumnScale($this->_queryID, $fieldOffset);
\r
107 if ($sc == 0) $fld->type = 'INT';
\r
112 // 10% speedup to move MoveNext to child class
\r
113 function MoveNext()
\r
116 if (!$this->EOF) {
\r
117 $this->_currentRow++;
\r
118 if(@OCIfetchinto($this->_queryID,$this->fields,$this->fetchMode)) {
\r
119 global $ADODB_ANSI_PADDING_OFF;
\r
121 if ($this->fetchMode & OCI_ASSOC) $this->_updatefields();
\r
122 if (!empty($ADODB_ANSI_PADDING_OFF)) {
\r
123 foreach($this->fields as $k => $v) {
\r
124 if (is_string($v)) $this->fields[$k] = rtrim($v);
\r
134 /* Optimize SelectLimit() by using OCIFetch() instead of OCIFetchInto() */
\r
135 function &GetArrayLimit($nrows,$offset=-1)
\r
137 if ($offset <= 0) return $this->GetArray($nrows);
\r
138 for ($i=1; $i < $offset; $i++)
\r
139 if (!@OCIFetch($this->_queryID)) return array();
\r
141 if (!@OCIfetchinto($this->_queryID,$this->fields,$this->fetchMode)) return array();
\r
142 if ($this->fetchMode & OCI_ASSOC) $this->_updatefields();
\r
143 $results = array();
\r
145 while (!$this->EOF && $nrows != $cnt) {
\r
146 $results[$cnt++] = $this->fields;
\r
153 // Create associative array
\r
154 function _updatefields()
\r
156 if (ADODB_ASSOC_CASE == 2) return; // native
\r
159 $lowercase = (ADODB_ASSOC_CASE == 0);
\r
161 foreach($this->fields as $k => $v) {
\r
162 if (is_integer($k)) $arr[$k] = $v;
\r
165 $arr[strtolower($k)] = $v;
\r
167 $arr[strtoupper($k)] = $v;
\r
170 $this->fields = $arr;
\r
175 $ret = @OCIfetchinto($this->_queryID,$this->fields,$this->fetchMode);
\r
177 global $ADODB_ANSI_PADDING_OFF;
\r
179 if ($this->fetchMode & OCI_ASSOC) $this->_updatefields();
\r
180 if (!empty($ADODB_ANSI_PADDING_OFF)) {
\r
181 foreach($this->fields as $k => $v) {
\r
182 if (is_string($v)) $this->fields[$k] = rtrim($v);
\r