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


PHP Selection::getName方法代碼示例

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


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

示例1: getCount

 /**
  * Get count of data
  * @return int
  */
 public function getCount()
 {
     try {
         $primary = $this->data_source->getPrimary();
     } catch (\LogicException $e) {
         return $this->data_source->count('*');
     }
     return $this->data_source->count($this->data_source->getName() . '.' . (is_array($primary) ? reset($primary) : $primary));
 }
開發者ID:ublaboo,項目名稱:datagrid,代碼行數:13,代碼來源:NetteDatabaseTableDataSource.php

示例2: buildJoins

 protected function buildJoins($val, $inner = FALSE)
 {
     $driver = $this->selection->getConnection()->getSupplementalDriver();
     $reflection = $this->selection->getConnection()->getDatabaseReflection();
     $joins = array();
     preg_match_all('~\\b([a-z][\\w.:]*[.:])([a-z]\\w*|\\*)(\\s+IS\\b|\\s*<=>)?~i', $val, $matches);
     foreach ($matches[1] as $names) {
         $parent = $this->selection->getName();
         if ($names !== "{$parent}.") {
             // case-sensitive
             preg_match_all('~\\b([a-z][\\w]*|\\*)([.:])~i', $names, $matches, PREG_SET_ORDER);
             foreach ($matches as $match) {
                 list(, $name, $delimiter) = $match;
                 if ($delimiter === ':') {
                     list($table, $primary) = $reflection->getHasManyReference($parent, $name);
                     $column = $reflection->getPrimary($parent);
                 } else {
                     list($table, $column) = $reflection->getBelongsToReference($parent, $name);
                     $primary = $reflection->getPrimary($table);
                 }
                 $joins[$name] = ' ' . (!isset($joins[$name]) && $inner && !isset($match[3]) ? 'INNER' : 'LEFT') . ' JOIN ' . $driver->delimite($table) . ($table !== $name ? ' AS ' . $driver->delimite($name) : '') . ' ON ' . $driver->delimite($parent) . '.' . $driver->delimite($column) . ' = ' . $driver->delimite($name) . '.' . $driver->delimite($primary);
                 $parent = $name;
             }
         }
     }
     return $joins;
 }
開發者ID:cujan,項目名稱:atlas-mineralov-a-hornin,代碼行數:27,代碼來源:SqlBuilder.php

示例3: related

 /**
  * Returns referencing rows.
  * @param  string
  * @param  string
  * @return GroupedSelection
  */
 public function related($key, $throughColumn = NULL)
 {
     $groupedSelection = $this->table->getReferencingTable($key, $throughColumn, $this[$this->table->getPrimary()]);
     if (!$groupedSelection) {
         throw new Nette\MemberAccessException("No reference found for \${$this->table->getName()}->related({$key}).");
     }
     return $groupedSelection;
 }
開發者ID:nette,項目名稱:database,代碼行數:14,代碼來源:ActiveRow.php

示例4: offsetGet

 /**
  * Returns specified row.
  *
  * @param mixed $key Row's primary key
  * @return HyperRow|NULL if there is no such row
  */
 public function offsetGet($key)
 {
     $result = $this->selection->offsetGet($key);
     if ($result instanceof ActiveRow) {
         return $this->factory->createRow($result, $this->selection->getName());
     }
     return $result;
 }
開發者ID:filsedla,項目名稱:hyperrow,代碼行數:14,代碼來源:HyperSelection.php

示例5: __isset

 public function __isset($key)
 {
     $this->access($key);
     if (array_key_exists($key, $this->data)) {
         return isset($this->data[$key]);
     }
     list($table, $column) = $this->table->getConnection()->getDatabaseReflection()->getBelongsToReference($this->table->getName(), $key);
     $referenced = $this->getReference($table, $column);
     if (!isset($referenced)) {
         $this->access($key, TRUE);
         return FALSE;
     }
     return TRUE;
 }
開發者ID:exesek,項目名稱:nette20login,代碼行數:14,代碼來源:ActiveRow.php

示例6: list

 public function &__get($key)
 {
     $this->access($key);
     if (array_key_exists($key, $this->data)) {
         return $this->data[$key];
     }
     $this->access($key, TRUE);
     list($table, $column) = $this->table->getConnection()->getDatabaseReflection()->getBelongsToReference($this->table->getName(), $key);
     $referenced = $this->getReference($table, $column);
     if ($referenced !== FALSE) {
         return $referenced;
     }
     throw new Nette\MemberAccessException("Cannot read an undeclared column \"{$key}\".");
 }
開發者ID:kravco,項目名稱:nette,代碼行數:14,代碼來源:ActiveRow.php

示例7: list

 public function &__get($key)
 {
     $this->accessColumn($key);
     if (array_key_exists($key, $this->data)) {
         return $this->data[$key];
     }
     try {
         list($table, $column) = $this->table->getDatabaseReflection()->getBelongsToReference($this->table->getName(), $key);
         $referenced = $this->getReference($table, $column);
         if ($referenced !== FALSE) {
             $this->accessColumn($key, FALSE);
             return $referenced;
         }
     } catch (MissingReferenceException $e) {
     }
     $this->removeAccessColumn($key);
     throw new Nette\MemberAccessException("Cannot read an undeclared column \"{$key}\".");
 }
開發者ID:Johnik010,項目名稱:rezervace,代碼行數:18,代碼來源:ActiveRow.php

示例8: createSelection

 /**
  * @param Selection $selection
  * @return HyperSelection
  */
 public function createSelection(Selection $selection)
 {
     $tableName = $selection->getName();
     $className = Helpers::substituteClassWildcard($this->selectionMapping, $tableName);
     $baseClass = HyperSelection::class;
     if (!class_exists($className) || !is_subclass_of($className, $baseClass)) {
         throw new InvalidStateException("HyperSelection class {$className} does not exist or does not extend {$baseClass}.");
     }
     $names = $this->container->findByType($className);
     if (count($names) > 1) {
         throw new InvalidStateException("Multiple services of type {$className} found: " . implode(', ', $names) . '.');
     } elseif (count($names) == 0) {
         $inst = $this->container->createInstance($className);
     } else {
         $name = array_shift($names);
         $inst = $this->container->createService($name);
     }
     /** @var HyperSelection $inst */
     $inst->setFactory($this);
     $inst->setSelection($selection);
     return $inst;
 }
開發者ID:filsedla,項目名稱:hyperrow,代碼行數:26,代碼來源:Factory.php

示例9: createRow

 /**
  * Creates a new row.
  * @param  mixed[]
  * @param  \Nette\Database\Table\Selection
  * @return \Nette\Database\Table\ActiveRow
  */
 public function createRow(array $data, \Nette\Database\Table\Selection $table)
 {
     $class = $this->getRowClass($table->getName());
     return new $class($data, $table);
 }
開發者ID:fabik,項目名稱:database,代碼行數:11,代碼來源:RowFactory.php


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