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


PHP Registry::setChangedTables方法代碼示例

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


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

示例1: query

 /**
  * Execute query
  *
  * @param string $query unparsed query
  * @param mixed ... unlimited number of variables for placeholders
  * @return mixed result set for "SELECT" statement / generated ID for an AUTO_INCREMENT field for insert statement / Affected rows count for DELETE/UPDATE statements
  */
 public static function query($query)
 {
     if (!self::$raw) {
         fn_set_hook('db_query', $query);
     }
     $args = func_get_args();
     $query = self::process($query, array_slice($args, 1), true);
     $result = false;
     if (!empty($query)) {
         if (!self::$raw) {
             fn_set_hook('db_query_process', $query);
         }
         if (defined('DEBUG_QUERIES')) {
             fn_print_r($query);
         }
         $time_start = microtime(true);
         $result = self::$_db->query($query);
         $a_row = self::$_db->affectedRows($result);
         Debugger::set_query($query, microtime(true) - $time_start);
         self::_error($result, $query);
         // Get last inserted ID
         $i_id = self::$_db->insertId();
         if (!self::$raw) {
             fn_set_hook('db_query_executed', $query, $result);
         }
         // "true" will be returned for Update/Delete/Insert/Replace statements. "SELECT" returns MySQLi/PDO object
         if ($result === true) {
             $cmd = substr($query, 0, 6);
             // Check if it was insert statement with auto_increment value and return it
             if (!empty($i_id)) {
                 $result = $i_id;
             } elseif ($cmd == 'UPDATE' || $cmd == 'DELETE' || $cmd == 'INSERT') {
                 $result = $a_row;
             }
             // Check if query updated data in the database and run cache handlers
             if (!empty($result) && preg_match("/^(UPDATE|INSERT INTO|REPLACE INTO|DELETE FROM) " . self::$_table_prefix . "(\\w+) /", $query, $m)) {
                 Registry::setChangedTables($m[2]);
             }
         }
     }
     self::$raw = false;
     return $result;
 }
開發者ID:OneataBogdan,項目名稱:lead_coriolan,代碼行數:50,代碼來源:Database.php

示例2: deleteTemplatesCache

 /**
  * Removes compiled block templates
  * @return bool
  */
 public static function deleteTemplatesCache()
 {
     static $is_deleted = false;
     if (!$is_deleted) {
         // mark cache as outdated
         Registry::setChangedTables('bm_blocks');
         // run cache routines
         Registry::save();
         $is_deleted = true;
     }
     return $is_deleted;
 }
開發者ID:arpad9,項目名稱:bygmarket,代碼行數:16,代碼來源:RenderManager.php

示例3: query

 /**
  * Execute query
  *
  * @param string $query unparsed query
  * @param mixed ... unlimited number of variables for placeholders
  * @return mixed result set for "SELECT" statement / generated ID for an AUTO_INCREMENT field for insert statement / Affected rows count for DELETE/UPDATE statements
  */
 public static function query($query)
 {
     if (!self::$raw) {
         fn_set_hook('db_query', $query);
     }
     $args = func_get_args();
     $query = self::process($query, array_slice($args, 1), true);
     $result = false;
     if (!empty($query)) {
         if (!self::$raw) {
             fn_set_hook('db_query_process', $query);
         }
         if (defined('DEBUG_QUERIES')) {
             fn_print_r($query);
         }
         $time_start = microtime(true);
         $result = self::$db->query($query);
         if (!self::error($result, $query)) {
             $insert_id = self::$db->insertId();
             Debugger::set_query($query, microtime(true) - $time_start);
             if (!self::$raw) {
                 fn_set_hook('db_query_executed', $query, $result);
             }
             // "true" will be returned for Update/Delete/Insert/Replace statements. "SELECT" returns MySQLi/PDO object
             if ($result === true) {
                 $cmd = substr($query, 0, 6);
                 // Check if it was insert statement with auto_increment value and return it
                 if (!empty($insert_id)) {
                     $result = $insert_id;
                 } elseif ($cmd == 'UPDATE' || $cmd == 'DELETE' || $cmd == 'INSERT') {
                     $result = self::$db->affectedRows($result);
                 }
                 // Check if query updated data in the database and run cache handlers
                 if (!empty($result) && preg_match("/^(UPDATE|INSERT INTO|REPLACE INTO|DELETE FROM) " . self::$table_prefix . "(\\w+) /", $query, $m)) {
                     Registry::setChangedTables($m[2]);
                 }
             }
         } else {
             // Lost connection, try to reconnect
             if (self::tryReconnect()) {
                 return self::query($query);
                 // Assume that the table is broken
                 // Try to repair
             } elseif (preg_match("/'(\\S+)\\.(MYI|MYD)/", self::$db->error(), $matches)) {
                 self::$db->query("REPAIR TABLE {$matches['1']}");
                 return self::query($query);
             }
         }
     }
     self::$raw = false;
     return $result;
 }
開發者ID:askzap,項目名稱:ultimate,代碼行數:59,代碼來源:Database.php


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