當前位置: 首頁>>代碼示例>>PHP>>正文


PHP sDB::caller方法代碼示例

本文整理匯總了PHP中sDB::caller方法的典型用法代碼示例。如果您正苦於以下問題:PHP sDB::caller方法的具體用法?PHP sDB::caller怎麽用?PHP sDB::caller使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在sDB的用法示例。


在下文中一共展示了sDB::caller方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: query

 /**
  * Send a query to the database and retrieve the results
  *
  * Results can be formatted using 'auto', 'object' or 'array'.
  *
  *    auto - Automatically detects 'object' and 'array' results (default)
  *  object - Provides a single object as the result
  *   array - Provides a list of records/objects
  *
  * Processing results can also be automated by specifying a record processor
  * function. A custom callback function can be provided using standard PHP
  * callback notation, or there are builtin record processing methods
  * supported that can be specified as a string in the callback
  * parameter: 'auto', 'index' or 'col'
  *
  *  auto - Simply adds a record to the result set as a numerically indexed array of records
  *
  * index - Indexes record objects into an associative array using a given column name as the key
  *         sDB::query('query', 'format', 'index', 'column', (bool)collate)
  *         A column name is provided (4th argument) for the index key value
  *         A 'collate' boolean flag can also be provided (5th argument) to collect records with identical index column values into an array
  *
  *   col - Builds records as an associative array with a single column as the array value
  *         sDB::query('query', 'format', 'column', 'indexcolumn', (bool)collate)
  *         A column name is provided (4th argument) as the column for the array value
  *         An index column name can be provided (5th argument) to index records as an associative array using the index column value as the key
  *         A 'collate' boolean flag can also be provided (6th argument) to collect records with identical index column values into an array
  *
  * Collating records using the 'index' or 'col' record processors require an index column.
  * When a record's column value matches another record, the two records are collected into
  * a nested array. The results array will have a single entry where the key is the
  * index column's value and the value of the entry is an array of all the records that share
  * the index column value.
  *
  * @author Jonathan Davis
  * @since 1.0
  * @version 1.2
  *
  * @param string $query The SQL query to send
  * @param string $format (optional) Supports 'auto' (default), 'object', or 'array'
  * @return array|object The query results as an object or array of result rows
  **/
 public static function query($query, $format = 'auto', $callback = false)
 {
     $db = sDB::get();
     $args = func_get_args();
     $args = count($args) > 3 ? array_slice($args, 3) : array();
     if (SHOPP_QUERY_DEBUG) {
         $timer = microtime(true);
     }
     $result = $db->api->query($query);
     if (SHOPP_QUERY_DEBUG) {
         $db->queries[] = array($query, microtime(true) - $timer, sDB::caller());
     }
     // Error handling
     if ($db->dbh && ($error = $db->api->error())) {
         shopp_add_error(sprintf('Query failed: %s - DB Query: %s', $error, str_replace("\n", "", $query)), SHOPP_DB_ERR);
         return false;
     }
     /** Results handling **/
     // Handle special cases
     if (preg_match("/^\\s*(create|drop|insert|delete|update|replace) /i", $query)) {
         if (!$result) {
             return false;
         }
         $db->affected = $db->api->affected();
         if (preg_match("/^\\s*(insert|replace) /i", $query)) {
             $insert = $db->api->object($db->api->query("SELECT LAST_INSERT_ID() AS id"));
             if (!empty($insert->id)) {
                 return (int) $insert->id;
             }
         }
         if ($db->affected > 0) {
             return $db->affected;
         } else {
             return true;
         }
     } elseif (preg_match("/ SQL_CALC_FOUND_ROWS /i", $query)) {
         $rows = $db->api->object($db->api->query("SELECT FOUND_ROWS() AS found"));
     }
     // Default data processing
     if (is_bool($result)) {
         return (bool) $result;
     }
     // Setup record processing callback
     if (is_string($callback) && !function_exists($callback)) {
         $callback = array(__CLASS__, $callback);
     }
     // Failsafe if callback isn't valid
     if (!$callback || is_array($callback) && !method_exists($callback[0], $callback[1])) {
         $callback = array(__CLASS__, 'auto');
     }
     // Process each row through the record processing callback
     $records = array();
     while ($row = $db->api->object($result)) {
         call_user_func_array($callback, array_merge(array(&$records, &$row), $args));
     }
     // Free the results immediately to save memory
     $db->api->free();
     // Save the found count if it is present
//.........這裏部分代碼省略.........
開發者ID:crunnells,項目名稱:shopp,代碼行數:101,代碼來源:DB.php


注:本文中的sDB::caller方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。