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


PHP Connection::escapeTable方法代碼示例

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


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

示例1: getMultiple

 /**
  * Implements Drupal\Core\Cache\CacheBackendInterface::getMultiple().
  */
 public function getMultiple(&$cids, $allow_invalid = FALSE)
 {
     $cid_mapping = array();
     foreach ($cids as $cid) {
         $cid_mapping[$this->normalizeCid($cid)] = $cid;
     }
     // When serving cached pages, the overhead of using ::select() was found
     // to add around 30% overhead to the request. Since $this->bin is a
     // variable, this means the call to ::query() here uses a concatenated
     // string. This is highly discouraged under any other circumstances, and
     // is used here only due to the performance overhead we would incur
     // otherwise. When serving an uncached page, the overhead of using
     // ::select() is a much smaller proportion of the request.
     $result = array();
     try {
         $result = $this->connection->query('SELECT cid, data, created, expire, serialized, tags, checksum_invalidations, checksum_deletions FROM {' . $this->connection->escapeTable($this->bin) . '} WHERE cid IN (:cids)', array(':cids' => array_keys($cid_mapping)));
     } catch (\Exception $e) {
         // Nothing to do.
     }
     $cache = array();
     foreach ($result as $item) {
         // Map the cache ID back to the original.
         $item->cid = $cid_mapping[$item->cid];
         $item = $this->prepareItem($item, $allow_invalid);
         if ($item) {
             $cache[$item->cid] = $item;
         }
     }
     $cids = array_diff($cids, array_keys($cache));
     return $cache;
 }
開發者ID:anatalsceo,項目名稱:en-classe,代碼行數:34,代碼來源:DatabaseBackend.php

示例2: getAllCollectionNames

 /**
  * {@inheritdoc}
  */
 public function getAllCollectionNames()
 {
     try {
         return $this->connection->query('SELECT DISTINCT collection FROM {' . $this->connection->escapeTable($this->table) . '} WHERE collection <> :collection ORDER by collection', array(':collection' => StorageInterface::DEFAULT_COLLECTION))->fetchCol();
     } catch (\Exception $e) {
         return array();
     }
 }
開發者ID:anatalsceo,項目名稱:en-classe,代碼行數:11,代碼來源:DatabaseStorage.php

示例3: getAll

 /**
  * Implements Drupal\Core\KeyValueStore\KeyValueStoreInterface::getAll().
  */
 public function getAll()
 {
     $result = $this->connection->query('SELECT name, value FROM {' . $this->connection->escapeTable($this->table) . '} WHERE collection = :collection', array(':collection' => $this->collection));
     $values = array();
     foreach ($result as $item) {
         if ($item) {
             $values[$item->name] = $this->serializer->decode($item->value);
         }
     }
     return $values;
 }
開發者ID:EarthTeam,項目名稱:earthteam.net,代碼行數:14,代碼來源:DatabaseStorage.php

示例4: getRoutesByPath

 /**
  * Get all routes which match a certain pattern.
  *
  * @param string $path
  *   The route pattern to search for (contains % as placeholders).
  *
  * @return \Symfony\Component\Routing\RouteCollection
  *   Returns a route collection of matching routes.
  */
 protected function getRoutesByPath($path)
 {
     // Filter out each empty value, though allow '0' and 0, which would be
     // filtered out by empty().
     $parts = array_values(array_filter(explode('/', $path), function ($value) {
         return $value !== NULL && $value !== '';
     }));
     $collection = new RouteCollection();
     $ancestors = $this->getCandidateOutlines($parts);
     if (empty($ancestors)) {
         return $collection;
     }
     $routes = $this->connection->query("SELECT name, route FROM {" . $this->connection->escapeTable($this->tableName) . "} WHERE pattern_outline IN (:patterns) ORDER BY fit DESC, name ASC", array(':patterns' => $ancestors))->fetchAllKeyed();
     foreach ($routes as $name => $route) {
         $route = unserialize($route);
         if (preg_match($route->compile()->getRegex(), $path, $matches)) {
             $collection->add($name, $route);
         }
     }
     return $collection;
 }
開發者ID:davidsoloman,項目名稱:drupalconsole.com,代碼行數:30,代碼來源:RouteProvider.php

示例5: getRoutesCount

 /**
  * {@inheritdoc}
  */
 public function getRoutesCount()
 {
     return $this->connection->query("SELECT COUNT(*) FROM {" . $this->connection->escapeTable($this->tableName) . "}")->fetchField();
 }
開發者ID:papillon-cendre,項目名稱:d8,代碼行數:7,代碼來源:RouteProvider.php

示例6: escapeTable

 /**
  * {@inheritdoc}
  */
 public function escapeTable($table)
 {
     $escaped = parent::escapeTable($table);
     // Quote identifier to make it case-sensitive.
     if (preg_match('/[A-Z]/', $escaped)) {
         $escaped = '"' . $escaped . '"';
     }
     return $escaped;
 }
開發者ID:Nikola-xiii,項目名稱:d8intranet,代碼行數:12,代碼來源:Connection.php

示例7: escapeTable

 /**
  * {@inheritdoc}
  */
 public function escapeTable($table)
 {
     $escaped = parent::escapeTable($table);
     // Quote identifier to make it case-sensitive.
     if (preg_match('/[A-Z]/', $escaped)) {
         $escaped = '"' . $escaped . '"';
     } elseif (in_array(strtolower($escaped), $this->postgresqlReservedKeyWords)) {
         // Quote the table name for PostgreSQL reserved key words.
         $escaped = '"' . $escaped . '"';
     }
     return $escaped;
 }
開發者ID:papillon-cendre,項目名稱:d8,代碼行數:15,代碼來源:Connection.php

示例8: __construct

 /**
  * Constructs a Subscription object.
  *
  * @param \Drupal\Core\Database\Connection $connection
  *   The database connection object.
  * @param string $table
  *   The database table to perform queries on.
  */
 public function __construct(Connection $connection, $table)
 {
     $this->connection = $connection;
     $this->table = $table;
     $this->tableEscaped = $connection->escapeTable($this->table);
 }
開發者ID:alnutile,項目名稱:drunatra,代碼行數:14,代碼來源:Subscription.php

示例9: escapeTable

 /**
  * {@inheritdoc}
  */
 public function escapeTable($table)
 {
     $escaped = parent::escapeTable($table);
     // Ensure that each part (database, schema and table) of the table name is
     // properly and independently escaped.
     $parts = explode('.', $escaped);
     $parts = array_map([$this, 'doEscape'], $parts);
     $escaped = implode('.', $parts);
     return $escaped;
 }
開發者ID:eigentor,項目名稱:tommiblog,代碼行數:13,代碼來源:Connection.php


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