3 // security - hide paths
4 if (!defined('ADODB_DIR')) die();
6 global $ADODB_INCLUDED_LIB;
7 $ADODB_INCLUDED_LIB = 1;
10 @version V4.64 20 June 2005 (c) 2000-2005 John Lim (jlim\@natsoft.com.my). All rights reserved.
11 Released under both BSD license and Lesser GPL library license.
12 Whenever there is any discrepancy between the two licenses,
13 the BSD license will take precedence. See License.txt.
14 Set tabs to 4 for best viewing.
16 Less commonly used functions are placed here to reduce size of adodb.inc.php.
20 // Force key to upper.
21 // See also http://www.php.net/manual/en/function.array-change-key-case.php
22 function _array_change_key_case($an_array)
24 if (is_array($an_array)) {
26 foreach($an_array as $key=>$value)
27 $new_array[strtoupper($key)] = $value;
35 function _adodb_replace(&$zthis, $table, $fieldArray, $keyCol, $autoQuote, $has_autoinc)
37 if (count($fieldArray) == 0) return 0;
41 if (!is_array($keyCol)) {
42 $keyCol = array($keyCol);
44 foreach($fieldArray as $k => $v) {
45 if ($autoQuote && !is_numeric($v) and strncmp($v,"'",1) !== 0 and strcasecmp($v,'null')!=0) {
46 $v = $zthis->qstr($v);
49 if (in_array($k,$keyCol)) continue; // skip UPDATE if is key
59 foreach ($keyCol as $v) {
60 if ($where) $where .= " and $v=$fieldArray[$v]";
61 else $where = "$v=$fieldArray[$v]";
64 if ($uSet && $where) {
65 $update = "UPDATE $table SET $uSet WHERE $where";
67 $rs = $zthis->Execute($update);
71 if ($zthis->poorAffectedRows
) {
73 The Select count(*) wipes out any errors that the update would have returned.
74 http://phplens.com/lens/lensforum/msgs.php?id=5696
76 if ($zthis->ErrorNo()<>0) return 0;
78 # affected_rows == 0 if update field values identical to old values
79 # for mysql - which is silly.
81 $cnt = $zthis->GetOne("select count(*) from $table where $where");
82 if ($cnt > 0) return 1; // record already exists
84 if (($zthis->Affected_Rows()>0)) return 1;
90 // print "<p>Error=".$this->ErrorNo().'<p>';
92 foreach($fieldArray as $k => $v) {
93 if ($has_autoinc && in_array($k,$keyCol)) continue; // skip autoinc col
104 $insert = "INSERT INTO $table ($iCols) VALUES ($iVals)";
105 $rs = $zthis->Execute($insert);
106 return ($rs) ?
2 : 0;
109 // Requires $ADODB_FETCH_MODE = ADODB_FETCH_NUM
110 function _adodb_getmenu(&$zthis, $name,$defstr='',$blank1stItem=true,$multiple=false,
111 $size=0, $selectAttr='',$compareFields0=true)
115 if ($multiple or is_array($defstr)) {
116 if ($size==0) $size=5;
117 $attr = ' multiple size="'.$size.'"';
118 if (!strpos($name,'[]')) $name .= '[]';
119 } else if ($size) $attr = ' size="'.$size.'"';
122 $s = '<select name="'.$name.'"'.$attr.' '.$selectAttr.'>';
124 if (is_string($blank1stItem)) {
125 $barr = explode(':',$blank1stItem);
126 if (sizeof($barr) == 1) $barr[] = '';
127 $s .= "\n<option value=\"".$barr[0]."\">".$barr[1]."</option>";
128 } else $s .= "\n<option></option>";
130 if ($zthis->FieldCount() > 1) $hasvalue=true;
131 else $compareFields0 = true;
136 $fieldsize = sizeof($zthis->fields
);
137 while(!$zthis->EOF
) {
138 $zval = rtrim(reset($zthis->fields
));
140 if ($blank1stItem && $zval=="") {
145 if ($fieldsize > 1) {
146 if (isset($zthis->fields
[1]))
147 $zval2 = rtrim($zthis->fields
[1]);
149 $zval2 = rtrim(next($zthis->fields
));
151 $selected = ($compareFields0) ?
$zval : $zval2;
154 if ($fieldsize > 2) {
155 $group = rtrim($zthis->fields
[2]);
158 if ($optgroup != $group) {
162 $s .="\n<optgroup label='". htmlspecialchars($group) ."'>";
164 $s .="\n</optgroup>";
165 $s .="\n<optgroup label='". htmlspecialchars($group) ."'>";
170 $value = " value='".htmlspecialchars($zval2)."'";
172 if (is_array($defstr)) {
174 if (in_array($selected,$defstr))
175 $s .= "\n<option selected='selected'$value>".htmlspecialchars($zval).'</option>';
177 $s .= "\n<option".$value.'>'.htmlspecialchars($zval).'</option>';
180 if (strcasecmp($selected,$defstr)==0)
181 $s .= "\n<option selected='selected'$value>".htmlspecialchars($zval).'</option>';
183 $s .= "\n<option".$value.'>'.htmlspecialchars($zval).'</option>';
188 // closing last optgroup
189 if($optgroup != null) {
190 $s .= "\n</optgroup>";
192 return $s ."\n</select>\n";
195 // Requires $ADODB_FETCH_MODE = ADODB_FETCH_NUM
196 function _adodb_getmenu_gp(&$zthis, $name,$defstr='',$blank1stItem=true,$multiple=false,
197 $size=0, $selectAttr='',$compareFields0=true)
201 if ($multiple or is_array($defstr)) {
202 if ($size==0) $size=5;
203 $attr = ' multiple size="'.$size.'"';
204 if (!strpos($name,'[]')) $name .= '[]';
205 } else if ($size) $attr = ' size="'.$size.'"';
208 $s = '<select name="'.$name.'"'.$attr.' '.$selectAttr.'>';
210 if (is_string($blank1stItem)) {
211 $barr = explode(':',$blank1stItem);
212 if (sizeof($barr) == 1) $barr[] = '';
213 $s .= "\n<option value=\"".$barr[0]."\">".$barr[1]."</option>";
214 } else $s .= "\n<option></option>";
216 if ($zthis->FieldCount() > 1) $hasvalue=true;
217 else $compareFields0 = true;
222 $fieldsize = sizeof($zthis->fields
);
223 while(!$zthis->EOF
) {
224 $zval = rtrim(reset($zthis->fields
));
226 if ($blank1stItem && $zval=="") {
231 if ($fieldsize > 1) {
232 if (isset($zthis->fields
[1]))
233 $zval2 = rtrim($zthis->fields
[1]);
235 $zval2 = rtrim(next($zthis->fields
));
237 $selected = ($compareFields0) ?
$zval : $zval2;
240 if (isset($zthis->fields
[2])) {
241 $group = rtrim($zthis->fields
[2]);
244 if ($optgroup != $group) {
248 $s .="\n<optgroup label='". htmlspecialchars($group) ."'>";
250 $s .="\n</optgroup>";
251 $s .="\n<optgroup label='". htmlspecialchars($group) ."'>";
256 $value = " value='".htmlspecialchars($zval2)."'";
258 if (is_array($defstr)) {
260 if (in_array($selected,$defstr))
261 $s .= "\n<option selected='selected'$value>".htmlspecialchars($zval).'</option>';
263 $s .= "\n<option".$value.'>'.htmlspecialchars($zval).'</option>';
266 if (strcasecmp($selected,$defstr)==0)
267 $s .= "\n<option selected='selected'$value>".htmlspecialchars($zval).'</option>';
269 $s .= "\n<option".$value.'>'.htmlspecialchars($zval).'</option>';
274 // closing last optgroup
275 if($optgroup != null) {
276 $s .= "\n</optgroup>";
278 return $s ."\n</select>\n";
283 Count the number of records this sql statement will return by using
284 query rewriting techniques...
286 Does not work with UNIONs, except with postgresql and oracle.
288 function _adodb_getcount(&$zthis, $sql,$inputarr=false,$secs2cache=0)
292 if (preg_match("/^\s*SELECT\s+DISTINCT/is", $sql) ||
293 preg_match('/\s+GROUP\s+BY\s+/is',$sql) ||
294 preg_match('/\s+UNION\s+/is',$sql)) {
295 // ok, has SELECT DISTINCT or GROUP BY so see if we can use a table alias
296 // but this is only supported by oracle and postgresql...
297 if ($zthis->dataProvider
== 'oci8') {
299 $rewritesql = preg_replace('/(\sORDER\s+BY\s.*)/is','',$sql);
301 // Allow Oracle hints to be used for query optimization, Chris Wrye
302 if (preg_match('#/\\*+.*?\\*\\/#', $sql, $hint)) {
303 $rewritesql = "SELECT ".$hint[0]." COUNT(*) FROM (".$rewritesql.")";
305 $rewritesql = "SELECT COUNT(*) FROM (".$rewritesql.")";
307 } else if (strncmp($zthis->databaseType
,'postgres',8) == 0) {
309 $info = $zthis->ServerInfo();
310 if (substr($info['version'],0,3) >= 7.1) { // good till version 999
311 $rewritesql = preg_replace('/(\sORDER\s+BY\s[^)]*)/is','',$sql);
312 $rewritesql = "SELECT COUNT(*) FROM ($rewritesql) _ADODB_ALIAS_";
316 // now replace SELECT ... FROM with SELECT COUNT(*) FROM
317 $rewritesql = preg_replace(
318 '/^\s*SELECT\s.*\s+FROM\s/Uis','SELECT COUNT(*) FROM ',$sql);
320 // fix by alexander zhukov, alex#unipack.ru, because count(*) and 'order by' fails
321 // with mssql, access and postgresql. Also a good speedup optimization - skips sorting!
322 $rewritesql = preg_replace('/(\sORDER\s+BY\s[^)]*)/is','',$rewritesql);
325 if (isset($rewritesql) && $rewritesql != $sql) {
327 // we only use half the time of secs2cache because the count can quickly
328 // become inaccurate if new records are added
329 $qryRecs = $zthis->CacheGetOne($secs2cache/2,$rewritesql,$inputarr);
332 $qryRecs = $zthis->GetOne($rewritesql,$inputarr);
334 if ($qryRecs !== false) return $qryRecs;
336 //--------------------------------------------
337 // query rewrite failed - so try slower way...
340 // strip off unneeded ORDER BY if no UNION
341 if (preg_match('/\s*UNION\s*/is', $sql)) $rewritesql = $sql;
342 else $rewritesql = preg_replace('/(\sORDER\s+BY\s.*)/is','',$sql);
344 $rstest = &$zthis->Execute($rewritesql,$inputarr);
345 if (!$rstest) $rstest = $zthis->Execute($sql,$inputarr);
348 $qryRecs = $rstest->RecordCount();
349 if ($qryRecs == -1) {
350 global $ADODB_EXTENSION;
351 // some databases will return -1 on MoveLast() - change to MoveNext()
352 if ($ADODB_EXTENSION) {
353 while(!$rstest->EOF
) {
354 adodb_movenext($rstest);
357 while(!$rstest->EOF
) {
361 $qryRecs = $rstest->_currentRow
;
364 if ($qryRecs == -1) return 0;
371 Code originally from "Cornel G" <conyg@fx.ro>
373 This code might not work with SQL that has UNION in it
375 Also if you are using CachePageExecute(), there is a strong possibility that
376 data will get out of synch. use CachePageExecute() only with tables that
379 function &_adodb_pageexecute_all_rows(&$zthis, $sql, $nrows, $page,
380 $inputarr=false, $secs2cache=0)
382 $atfirstpage = false;
386 // If an invalid nrows is supplied,
387 // we assume a default value of 10 rows per page
388 if (!isset($nrows) ||
$nrows <= 0) $nrows = 10;
390 $qryRecs = false; //count records for no offset
392 $qryRecs = _adodb_getcount($zthis,$sql,$inputarr,$secs2cache);
393 $lastpageno = (int) ceil($qryRecs / $nrows);
394 $zthis->_maxRecordCount
= $qryRecs;
398 // ***** Here we check whether $page is the last page or
399 // whether we are trying to retrieve
400 // a page number greater than the last page number.
401 if ($page >= $lastpageno) {
406 // If page number <= 1, then we are at the first page
407 if (empty($page) ||
$page <= 1) {
412 // We get the data we want
413 $offset = $nrows * ($page-1);
415 $rsreturn = &$zthis->CacheSelectLimit($secs2cache, $sql, $nrows, $offset, $inputarr);
417 $rsreturn = &$zthis->SelectLimit($sql, $nrows, $offset, $inputarr, $secs2cache);
420 // Before returning the RecordSet, we set the pagination properties we need
422 $rsreturn->_maxRecordCount
= $qryRecs;
423 $rsreturn->rowsPerPage
= $nrows;
424 $rsreturn->AbsolutePage($page);
425 $rsreturn->AtFirstPage($atfirstpage);
426 $rsreturn->AtLastPage($atlastpage);
427 $rsreturn->LastPageNo($lastpageno);
432 // Iván Oliva version
433 function &_adodb_pageexecute_no_last_page(&$zthis, $sql, $nrows, $page, $inputarr=false, $secs2cache=0)
436 $atfirstpage = false;
439 if (!isset($page) ||
$page <= 1) { // If page number <= 1, then we are at the first page
443 if ($nrows <= 0) $nrows = 10; // If an invalid nrows is supplied, we assume a default value of 10 rows per page
445 // ***** Here we check whether $page is the last page or whether we are trying to retrieve a page number greater than
446 // the last page number.
447 $pagecounter = $page +
1;
448 $pagecounteroffset = ($pagecounter * $nrows) - $nrows;
449 if ($secs2cache>0) $rstest = &$zthis->CacheSelectLimit($secs2cache, $sql, $nrows, $pagecounteroffset, $inputarr);
450 else $rstest = &$zthis->SelectLimit($sql, $nrows, $pagecounteroffset, $inputarr, $secs2cache);
452 while ($rstest && $rstest->EOF
&& $pagecounter>0) {
455 $pagecounteroffset = $nrows * ($pagecounter - 1);
457 if ($secs2cache>0) $rstest = &$zthis->CacheSelectLimit($secs2cache, $sql, $nrows, $pagecounteroffset, $inputarr);
458 else $rstest = &$zthis->SelectLimit($sql, $nrows, $pagecounteroffset, $inputarr, $secs2cache);
460 if ($rstest) $rstest->Close();
462 if ($atlastpage) { // If we are at the last page or beyond it, we are going to retrieve it
463 $page = $pagecounter;
464 if ($page == 1) $atfirstpage = true; // We have to do this again in case the last page is the same as the first
465 //... page, that is, the recordset has only 1 page.
468 // We get the data we want
469 $offset = $nrows * ($page-1);
470 if ($secs2cache > 0) $rsreturn = &$zthis->CacheSelectLimit($secs2cache, $sql, $nrows, $offset, $inputarr);
471 else $rsreturn = &$zthis->SelectLimit($sql, $nrows, $offset, $inputarr, $secs2cache);
473 // Before returning the RecordSet, we set the pagination properties we need
475 $rsreturn->rowsPerPage
= $nrows;
476 $rsreturn->AbsolutePage($page);
477 $rsreturn->AtFirstPage($atfirstpage);
478 $rsreturn->AtLastPage($atlastpage);
483 function _adodb_getupdatesql(&$zthis,&$rs, $arrFields,$forceUpdate=false,$magicq=false,$force=2)
486 printf(ADODB_BAD_RS
,'GetUpdateSQL');
490 $fieldUpdatedCount = 0;
491 $arrFields = _array_change_key_case($arrFields);
493 $hasnumeric = isset($rs->fields
[0]);
496 // Loop through all of the fields in the recordset
497 for ($i=0, $max=$rs->FieldCount(); $i < $max; $i++
) {
498 // Get the field from the recordset
499 $field = $rs->FetchField($i);
501 // If the recordset field is one
502 // of the fields passed in then process.
503 $upperfname = strtoupper($field->name
);
504 if (adodb_key_exists($upperfname,$arrFields,$force)) {
506 // If the existing field value in the recordset
507 // is different from the value passed in then
508 // go ahead and append the field name and new value to
511 if ($hasnumeric) $val = $rs->fields
[$i];
512 else if (isset($rs->fields
[$upperfname])) $val = $rs->fields
[$upperfname];
513 else if (isset($rs->fields
[$field->name
])) $val = $rs->fields
[$field->name
];
514 else if (isset($rs->fields
[strtolower($upperfname)])) $val = $rs->fields
[strtolower($upperfname)];
518 if ($forceUpdate ||
strcmp($val, $arrFields[$upperfname])) {
519 // Set the counter for the number of fields that will be updated.
520 $fieldUpdatedCount++
;
522 // Based on the datatype of the field
523 // Format the value properly for the database
524 $type = $rs->MetaType($field->type
);
527 if ($type == 'null') {
531 if (strpos($upperfname,' ') !== false)
532 $fnameq = $zthis->nameQuote
.$upperfname.$zthis->nameQuote
;
534 $fnameq = $upperfname;
537 // is_null requires php 4.0.4
538 //********************************************************//
539 if (is_null($arrFields[$upperfname])
540 ||
(empty($arrFields[$upperfname]) && strlen($arrFields[$upperfname]) == 0)
541 ||
$arrFields[$upperfname] === 'null'
547 // //Ignore empty values. This is allready handled in "adodb_key_exists" function.
552 $setFields .= $field->name
. " = null, ";
557 $arrFields[$upperfname] = "";
558 $setFields .= _adodb_column_sql($zthis, 'U', $type, $upperfname, $fnameq,$arrFields, $magicq);
562 //Set the value that was given in array, so you can give both null and empty values
563 if (is_null($arrFields[$upperfname]) ||
$arrFields[$upperfname] === 'null') {
564 $setFields .= $field->name
. " = null, ";
566 $setFields .= _adodb_column_sql($zthis, 'U', $type, $upperfname, $fnameq,$arrFields, $magicq);
570 //********************************************************//
572 //we do this so each driver can customize the sql for
573 //DB specific column types.
574 //Oracle needs BLOB types to be handled with a returning clause
575 //postgres has special needs as well
576 $setFields .= _adodb_column_sql($zthis, 'U', $type, $upperfname, $fnameq,
577 $arrFields, $magicq);
583 // If there were any modified fields then build the rest of the update query.
584 if ($fieldUpdatedCount > 0 ||
$forceUpdate) {
585 // Get the table name from the existing query.
586 if (!empty($rs->tableName
)) $tableName = $rs->tableName
;
587 else preg_match("/FROM\s+".ADODB_TABLE_REGEX
."/is", $rs->sql
, $tableName);
589 // Get the full where clause excluding the word "WHERE" from
590 // the existing query.
591 preg_match('/\sWHERE\s(.*)/is', $rs->sql
, $whereClause);
594 // not a good hack, improvements?
596 if (preg_match('/\s(ORDER\s.*)/is', $whereClause[1], $discard));
597 else if (preg_match('/\s(LIMIT\s.*)/is', $whereClause[1], $discard));
598 else preg_match('/\s(FOR UPDATE.*)/is', $whereClause[1], $discard);
600 $whereClause = array(false,false);
603 $whereClause[1] = substr($whereClause[1], 0, strlen($whereClause[1]) - strlen($discard[1]));
605 $sql = 'UPDATE '.$tableName[1].' SET '.substr($setFields, 0, -2);
606 if (strlen($whereClause[1]) > 0)
607 $sql .= ' WHERE '.$whereClause[1];
616 function adodb_key_exists($key, &$arr,$force=2)
619 // the following is the old behaviour where null or empty fields are ignored
620 return (!empty($arr[$key])) ||
(isset($arr[$key]) && strlen($arr[$key])>0);
623 if (isset($arr[$key])) return true;
625 if (ADODB_PHPVER
>= 0x4010) return array_key_exists($key,$arr);
630 * There is a special case of this function for the oci8 driver.
631 * The proper way to handle an insert w/ a blob in oracle requires
632 * a returning clause with bind variables and a descriptor blob.
636 function _adodb_getinsertsql(&$zthis,&$rs,$arrFields,$magicq=false,$force=2)
638 static $cacheRS = false;
639 static $cacheSig = 0;
646 $arrFields = _array_change_key_case($arrFields);
647 $fieldInsertedCount = 0;
649 if (is_string($rs)) {
650 //ok we have a table name
651 //try and get the column info ourself.
654 //we need an object for the recordSet
655 //because we have to call MetaType.
656 //php can't do a $rsclass::MetaType()
657 $rsclass = $zthis->rsPrefix
.$zthis->databaseType
;
658 $recordSet =& new $rsclass(-1,$zthis->fetchMode
);
659 $recordSet->connection
= &$zthis;
661 if (is_string($cacheRS) && $cacheRS == $rs) {
662 $columns =& $cacheCols;
664 $columns = $zthis->MetaColumns( $tableName );
665 $cacheRS = $tableName;
666 $cacheCols = $columns;
668 } else if (is_subclass_of($rs, 'adorecordset')) {
669 if (isset($rs->insertSig
) && is_integer($cacheRS) && $cacheRS == $rs->insertSig
) {
670 $columns =& $cacheCols;
672 for ($i=0, $max=$rs->FieldCount(); $i < $max; $i++
)
673 $columns[] = $rs->FetchField($i);
674 $cacheRS = $cacheSig;
675 $cacheCols = $columns;
676 $rs->insertSig
= $cacheSig++
;
681 printf(ADODB_BAD_RS
,'GetInsertSQL');
685 // Loop through all of the fields in the recordset
686 foreach( $columns as $field ) {
687 $upperfname = strtoupper($field->name
);
688 if (adodb_key_exists($upperfname,$arrFields,$force)) {
690 if (strpos($upperfname,' ') !== false)
691 $fnameq = $zthis->nameQuote
.$upperfname.$zthis->nameQuote
;
693 $fnameq = $upperfname;
695 $type = $recordSet->MetaType($field->type
);
697 /********************************************************/
698 if (is_null($arrFields[$upperfname])
699 ||
(empty($arrFields[$upperfname]) && strlen($arrFields[$upperfname]) == 0)
700 ||
$arrFields[$upperfname] === 'null'
705 case 0: // we must always set null if missing
715 $arrFields[$upperfname] = "";
716 $values .= _adodb_column_sql($zthis, 'I', $type, $upperfname, $fnameq,$arrFields, $magicq);
721 //Set the value that was given in array, so you can give both null and empty values
722 if (is_null($arrFields[$upperfname]) ||
$arrFields[$upperfname] === 'null') {
725 $values .= _adodb_column_sql($zthis, 'I', $type, $upperfname, $fnameq, $arrFields, $magicq);
730 /*********************************************************/
732 //we do this so each driver can customize the sql for
733 //DB specific column types.
734 //Oracle needs BLOB types to be handled with a returning clause
735 //postgres has special needs as well
736 $values .= _adodb_column_sql($zthis, 'I', $type, $upperfname, $fnameq,
737 $arrFields, $magicq);
741 // Set the counter for the number of fields that will be inserted.
742 $fieldInsertedCount++
;
745 // Get the name of the fields to insert
746 $fields .= $fnameq . ", ";
751 // If there were any inserted fields then build the rest of the insert query.
752 if ($fieldInsertedCount <= 0) return false;
754 // Get the table name from the existing query.
756 if (!empty($rs->tableName
)) $tableName = $rs->tableName
;
757 else if (preg_match("/FROM\s+".ADODB_TABLE_REGEX
."/is", $rs->sql
, $tableName))
758 $tableName = $tableName[1];
763 // Strip off the comma and space on the end of both the fields
765 $fields = substr($fields, 0, -2);
766 $values = substr($values, 0, -2);
768 // Append the fields and their values to the insert query.
769 return 'INSERT INTO '.$tableName.' ( '.$fields.' ) VALUES ( '.$values.' )';
774 * This private method is used to help construct
775 * the update/sql which is generated by GetInsertSQL and GetUpdateSQL.
776 * It handles the string construction of 1 column -> sql string based on
777 * the column type. We want to do 'safe' handling of BLOBs
779 * @param string the type of sql we are trying to create
781 * @param string column data type from the db::MetaType() method
782 * @param string the column name
783 * @param array the column value
788 function _adodb_column_sql_oci8(&$zthis,$action, $type, $fname, $fnameq, $arrFields, $magicq)
792 // Based on the datatype of the field
793 // Format the value properly for the database
796 //in order to handle Blobs correctly, we need
797 //to do some magic for Oracle
799 //we need to create a new descriptor to handle
801 if (!empty($zthis->hasReturningInto
)) {
802 if ($action == 'I') {
803 $sql = 'empty_blob(), ';
805 $sql = $fnameq. '=empty_blob(), ';
807 //add the variable to the returning clause array
808 //so the user can build this later in
809 //case they want to add more to it
810 $zthis->_returningArray
[$fname] = ':xx'.$fname.'xx';
811 } else if (empty($arrFields[$fname])){
812 if ($action == 'I') {
813 $sql = 'empty_blob(), ';
815 $sql = $fnameq. '=empty_blob(), ';
818 //this is to maintain compatibility
819 //with older adodb versions.
820 $sql = _adodb_column_sql($zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq,false);
825 //we need to do some more magic here for long variables
826 //to handle these correctly in oracle.
828 //create a safe bind var name
829 //to avoid conflicts w/ dupes.
830 if (!empty($zthis->hasReturningInto
)) {
831 if ($action == 'I') {
832 $sql = ':xx'.$fname.'xx, ';
834 $sql = $fnameq.'=:xx'.$fname.'xx, ';
836 //add the variable to the returning clause array
837 //so the user can build this later in
838 //case they want to add more to it
839 $zthis->_returningArray
[$fname] = ':xx'.$fname.'xx';
841 //this is to maintain compatibility
842 //with older adodb versions.
843 $sql = _adodb_column_sql($zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq,false);
848 $sql = _adodb_column_sql($zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq,false);
855 function _adodb_column_sql(&$zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq, $recurse=true)
859 switch($zthis->dataProvider
) {
861 if ($type == 'L') $type = 'C';
864 return _adodb_column_sql_oci8($zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq);
873 $val = $zthis->qstr($arrFields[$fname],$magicq);
877 $val = $zthis->DBDate($arrFields[$fname]);
881 $val = $zthis->DBTimeStamp($arrFields[$fname]);
885 $val = $arrFields[$fname];
886 if (empty($val)) $val = '0';
890 if ($action == 'I') return $val . ", ";
893 return $fnameq . "=" . $val . ", ";
899 function _adodb_debug_execute(&$zthis, $sql, $inputarr)
903 foreach($inputarr as $kk=>$vv) {
904 if (is_string($vv) && strlen($vv)>64) $vv = substr($vv,0,64).'...';
905 $ss .= "($kk=>'$vv') ";
909 $sqlTxt = is_array($sql) ?
$sql[0] : $sql;
910 /*str_replace(', ','##1#__^LF',is_array($sql) ? $sql[0] : $sql);
911 $sqlTxt = str_replace(',',', ',$sqlTxt);
912 $sqlTxt = str_replace('##1#__^LF', ', ' ,$sqlTxt);
914 // check if running from browser or command-line
915 $inBrowser = isset($_SERVER['HTTP_USER_AGENT']);
917 $dbt = $zthis->databaseType
;
918 if (isset($zthis->dsnType
)) $dbt .= '-'.$zthis->dsnType
;
920 $ss = htmlspecialchars($ss);
921 if ($zthis->debug
=== -1)
922 ADOConnection
::outp( "<br>\n($dbt): ".htmlspecialchars($sqlTxt)." <code>$ss</code>\n<br>\n",false);
924 ADOConnection
::outp( "<hr>\n($dbt): ".htmlspecialchars($sqlTxt)." <code>$ss</code>\n<hr>\n",false);
926 ADOConnection
::outp("-----\n($dbt): ".$sqlTxt."\n-----\n",false);
929 $qID = $zthis->_query($sql,$inputarr);
932 Alexios Fakios notes that ErrorMsg() must be called before ErrorNo() for mssql
933 because ErrorNo() calls Execute('SELECT @ERROR'), causing recursion
935 if ($zthis->databaseType
== 'mssql') {
936 // ErrorNo is a slow function call in mssql, and not reliable in PHP 4.0.6
937 if($emsg = $zthis->ErrorMsg()) {
938 if ($err = $zthis->ErrorNo()) ADOConnection
::outp($err.': '.$emsg);
941 ADOConnection
::outp($zthis->ErrorNo() .': '. $zthis->ErrorMsg());
944 if ($zthis->debug
=== 99) _adodb_backtrace(true,9999,2);
949 function _adodb_backtrace($printOrArr=true,$levels=9999,$skippy=0)
951 if (PHPVERSION() < 4.3) return '';
953 $html = (isset($_SERVER['HTTP_USER_AGENT']));
954 $fmt = ($html) ?
"</font><font color=#808080 size=-1> %% line %4d, file: <a href=\"file:/%s\">%s</a></font>" : "%% line %4d, file: %s";
958 $s = ($html) ?
'<pre align=left>' : '';
960 if (is_array($printOrArr)) $traceArr = $printOrArr;
961 else $traceArr = debug_backtrace();
962 array_shift($traceArr);
963 array_shift($traceArr);
964 $tabs = sizeof($traceArr)-2;
966 foreach ($traceArr as $arr) {
967 if ($skippy) {$skippy -= 1; continue;}
969 if ($levels < 0) break;
972 for ($i=0; $i < $tabs; $i++
) $s .= ($html) ?
' ' : "\t";
974 if ($html) $s .= '<font face="Courier New,Courier">';
975 if (isset($arr['class'])) $s .= $arr['class'].'.';
976 if (isset($arr['args']))
977 foreach($arr['args'] as $v) {
978 if (is_null($v)) $args[] = 'null';
979 else if (is_array($v)) $args[] = 'Array['.sizeof($v).']';
980 else if (is_object($v)) $args[] = 'Object:'.get_class($v);
981 else if (is_bool($v)) $args[] = $v ?
'true' : 'false';
984 $str = htmlspecialchars(substr($v,0,$MAXSTRLEN));
985 if (strlen($v) > $MAXSTRLEN) $str .= '...';
989 $s .= $arr['function'].'('.implode(', ',$args).')';
992 $s .= @sprintf
($fmt, $arr['line'],$arr['file'],basename($arr['file']));
996 if ($html) $s .= '</pre>';
997 if ($printOrArr) print $s;