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


PHP Selection::where方法代碼示例

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


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

示例1: filter

 /**
  * Filter data
  * @param array $filter
  */
 public function filter(array $filter)
 {
     foreach ($filter as $key => $value) {
         $value = is_numeric($value) ? $value : '%' . $value . '%';
         $this->table->where($key . ' LIKE ?', $value);
     }
 }
開發者ID:drahak,項目名稱:tables,代碼行數:11,代碼來源:DefaultDataSource.php

示例2: validate

 public function validate(BaseControl $control)
 {
     $condition[$control->name] = $control->value;
     if ($this->id) {
         $condition['id!='] = $this->id;
     }
     return $this->selection->where($condition)->count() ? FALSE : TRUE;
 }
開發者ID:04EO,項目名稱:TrainingTaskNette,代碼行數:8,代碼來源:UniqueValidator.php

示例3: setModel

 /**
  * Nastavi model
  * @param Nette\Database\Table\Selection
  */
 public function setModel(\Nette\Database\Table\Selection $model)
 {
     if (isset($this->filter['email']) && $this->filter['email'] != '') {
         $model->where('adress REGEXP ?', $this->filter['email']);
     }
     if (isset($this->filter['subject']) && $this->filter['subject'] != '') {
         $model->where('subject REGEXP ?', $this->filter['subject']);
     }
     $this->model = $model;
 }
開發者ID:vsek,項目名稱:base,代碼行數:14,代碼來源:GridEmailLog.php

示例4: getProdukt

 /** Nacitanie udajov o produkte
  * @param int $id Id produktu
  * @param int $id_lang Id jazyka
  * @return array|FALSE
  */
 public function getProdukt($id, $id_lang = 1)
 {
     $hlavne_menu_lang = $this->hlavne_menu_lang->where(array("id_hlavne_menu" => $id, "id_lang" => $id_lang));
     if ($hlavne_menu_lang === FALSE) {
         return FALSE;
     }
     $produkt = $this->find($hlavne_menu_lang->hlavne_menu->clanok);
     if ($produkt === FALSE) {
         return FALSE;
     }
     return array("hlavne_menu_lang" => $hlavne_menu_lang, "produkt" => $produkt);
 }
開發者ID:petak23,項目名稱:echo-msz,代碼行數:17,代碼來源:Produkt_lang.php

示例5: search

 public function search($q)
 {
     $query = "";
     $count = count($this->columns);
     $i = 0;
     $phldrs = array();
     foreach ($this->columns as $column) {
         $query .= new \Nette\Database\SqlLiteral($column . " " . $this->method . " ?");
         $phldrs[] = str_replace($this->placeholder, $q, $this->mask);
         if ($i < $count - 1) {
             $query .= " OR ";
         }
         $i++;
     }
     return $this->model->where($query, $phldrs);
 }
開發者ID:sg3tester,項目名稱:songator,代碼行數:16,代碼來源:Searcher.php

示例6: filter

 /**
  * Add filtering onto specified column
  *
  * @param string column name
  * @param string filter
  * @param string|array operation mode
  * @param string chain type (if third argument is array)
  * @return IDataSource (fluent)
  * @throws \Nette\InvalidArgumentException
  */
 public function filter($column, $operation = IDataSource::EQUAL, $value = NULL, $chainType = NULL)
 {
     if (!$this->hasColumn($column)) {
         throw new \Nette\InvalidArgumentException('Trying to filter data source by unknown column.');
     }
     if (is_array($operation)) {
         if ($chainType !== self::CHAIN_AND && $chainType !== self::CHAIN_OR) {
             throw new \Nette\InvalidArgumentException('Invalid chain operation type.');
         }
     } else {
         $operation = [$operation];
     }
     if (empty($operation)) {
         throw new \Nette\InvalidArgumentException('Operation cannot be empty.');
     }
     $conds = $values = [];
     foreach ($operation as $o) {
         $this->validateFilterOperation($o);
         $c = $this->mapping[$column] . " {$o}";
         if ($o !== self::IS_NULL && $o !== self::IS_NOT_NULL) {
             $c .= ' ?';
             $values[] = $o === self::LIKE || $o === self::NOT_LIKE ? DataSources\Utils\WildcardHelper::formatLikeStatementWildcards($value) : $value;
         }
         $conds[] = $c;
     }
     $conds = implode(" ( {$chainType} ) ", $conds);
     // "(cond1) OR (cond2) ..."  -- outer braces missing for now
     $this->selection->where("( {$conds} )", $values);
     return $this;
 }
開發者ID:lohini,項目名稱:cf,代碼行數:40,代碼來源:DB.php

示例7: filter

 /**
  * Filter IT!
  * @param string $flags
  */
 public function filter($flags)
 {
     //One and main logic!
     $columns = array();
     foreach (str_split($flags) as $char) {
         if (!array_key_exists($char, $this->flags)) {
             throw new \Nette\InvalidArgumentException("Unrecognized flag '{$char}'", 3315);
         }
         $flag = $this->flags[$char];
         if (!is_array($flag)) {
             $arr = array();
             $arr["column"] = $flag;
             $arr["by"] = " = 1";
             $columns[] = $arr;
         } else {
             $columns[] = $flag;
         }
     }
     return $this->model->where($this->getQueryString($columns));
 }
開發者ID:sg3tester,項目名稱:songator,代碼行數:24,代碼來源:FlagFilter.php

示例8: appendFilter

 static function appendFilter(Nette\Database\Table\Selection &$query, $filter = NULL, array $defaultFilterType = [], array $filterTranslate = [])
 {
     if (!is_null($filter)) {
         if (isset($filter[ABaseList::STRICT])) {
             $query->where($filter[ABaseList::STRICT]);
             unset($filter[ABaseList::STRICT]);
         }
         foreach ($filter as $k => $v) {
             $key = $k;
             if (array_key_exists($k, $filterTranslate)) {
                 $key = $filterTranslate[$k];
             }
             if (array_key_exists($k, $defaultFilterType)) {
                 switch ($defaultFilterType[$k]) {
                     case '<':
                         $query->where($key . ' < ?', $v);
                         break;
                     case '<=':
                         $query->where($key . ' <= ?', $v);
                         break;
                     case '<=date':
                         $query->where($key . ' < ? + INTERVAL 1 DAY', $v);
                         break;
                     case '>':
                         $query->where($key . ' > ?', $v);
                         break;
                     case '>=':
                         $query->where($key . ' >= ?', $v);
                         break;
                     case '=':
                         $query->where($key . ' = ?', $v);
                         break;
                     default:
                         throw new Trejjam\Utils\LogicException('Unknown filter type ' . $defaultFilterType[$k]);
                 }
             } else {
                 $query->where([$key . ' LIKE' => '%' . $v . '%']);
             }
         }
     }
     return $query;
 }
開發者ID:trejjam,項目名稱:utils,代碼行數:42,代碼來源:BaseQuery.php

示例9: __construct

 /**
  * @param Nette\Database\Table\Selection $dokumenty
  */
 public function __construct(Nette\Database\Table\Selection $dokumenty)
 {
     parent::__construct();
     //Najdem si len obrazky
     $this->dokumenty = $dokumenty->where("pripona", array("jpg", "png", "gif", "bmp"));
 }
開發者ID:petak23,項目名稱:echo-msz,代碼行數:9,代碼來源:NahodnaFotka.php

示例10: getReferencedTable

 /**
  * Returns referenced row.
  * @param  string
  * @return ActiveRow or NULL if the row does not exist
  */
 public function getReferencedTable($name, &$column = NULL)
 {
     $column = $this->connection->databaseReflection->getReferencedColumn($name, $this->name);
     $referenced =& $this->referenced[$name];
     if ($referenced === NULL) {
         $keys = array();
         foreach ($this->rows as $row) {
             if ($row[$column] !== NULL) {
                 $keys[$row[$column]] = NULL;
             }
         }
         if ($keys) {
             $table = $this->connection->databaseReflection->getReferencedTable($name, $this->name);
             $referenced = new Selection($table, $this->connection);
             $referenced->where($table . '.' . $this->getPrimary($table), array_keys($keys));
         } else {
             $referenced = array();
         }
     }
     return $referenced;
 }
開發者ID:rostenkowski,項目名稱:HttpPHPUnit,代碼行數:26,代碼來源:Selection.php

示例11: setModel

 public function setModel(\Nette\Database\Table\Selection $model)
 {
     parent::setModel($model->where('parent_id ?', null));
 }
開發者ID:vsek,項目名稱:grid,代碼行數:4,代碼來源:GridTree.php

示例12: getReferencedTable

 /**
  * Returns referenced row.
  * @param  string
  * @param  string
  * @param  bool  checks if rows contains the same primary value relations
  * @return ActiveRow or NULL if the row does not exist
  */
 public function getReferencedTable($table, $column, $checkReferenceNewKeys = FALSE)
 {
     $referenced =& $this->referenced[$table][$column];
     if ($referenced === NULL || $checkReferenceNewKeys || $this->checkReferenceNewKeys) {
         $keys = array();
         foreach ($this->rows as $row) {
             if ($row[$column] === NULL) {
                 continue;
             }
             $key = $row[$column] instanceof ActiveRow ? $row[$column]->getPrimary() : $row[$column];
             $keys[$key] = TRUE;
         }
         if ($referenced !== NULL && $keys === array_keys($this->rows)) {
             $this->checkReferenceNewKeys = FALSE;
             return $referenced;
         }
         if ($keys) {
             $referenced = new Selection($table, $this->connection);
             $referenced->where($table . '.' . $referenced->primary, array_keys($keys));
         } else {
             $referenced = array();
         }
     }
     return $referenced;
 }
開發者ID:exesek,項目名稱:nette20login,代碼行數:32,代碼來源:Selection.php

示例13: applyFilterSelect

 /**
  * Filter by select value
  * @param  Filter\FilterSelect $filter
  * @return void
  */
 public function applyFilterSelect(Filter\FilterSelect $filter)
 {
     $this->data_source->where($filter->getCondition());
 }
開發者ID:ublaboo,項目名稱:datagrid,代碼行數:9,代碼來源:NetteDatabaseTableDataSource.php

示例14: addCondition

 /**
  * @param $condition
  * @return self
  */
 public function addCondition($condition)
 {
     $this->selection->where($condition);
     return $this;
 }
開發者ID:jkrecek,項目名稱:nette-database-model,代碼行數:9,代碼來源:StoredCollection.php

示例15: filterSearch

 /**
  * Hleda vyraz ve sloupci.
  * @param \Nette\Database\Table\Selection $selection
  * @param string $column
  * @param string $word
  * @param string $via
  * @return \Nette\Database\Table\Selection
  */
 public function filterSearch(Selection $selection, $column, $word, $via = '')
 {
     return $selection->where("? LIKE ?", new \Nette\Database\SqlLiteral($column), "%{$word}%");
 }
開發者ID:kysela-petr,項目名稱:generator-kysela,代碼行數:12,代碼來源:ISFilter.php


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