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


PHP QueryBuilder::orWhere方法代碼示例

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


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

示例1: getNuArtefatoNuDigital

 public function getNuArtefatoNuDigital(\Doctrine\ORM\QueryBuilder &$queryBuilder, \Core_Dto_Search $dto)
 {
     if ($dto->getNuArtefato()) {
         $nuArtefato = str_replace(' ', '', str_replace('.', '', str_replace('/', '', str_replace('-', '', $dto->getNuArtefato()))));
         $queryBuilder->orWhere('vwca.nuDigital like :nuDigital')->setParameter('nuDigital', '%' . $dto->getNuArtefato() . '%');
         $queryBuilder->orWhere('vwca.nuArtefato like :nuArtefato')->setParameter('nuArtefato', '%' . $nuArtefato . '%');
     }
 }
開發者ID:sgdoc,項目名稱:sgdoce-codigo,代碼行數:8,代碼來源:VwConsultaArtefatoExtensao.php

示例2: restrict

 /**
  * {@inheritdoc}
  */
 public function restrict($expression, $condition = DataSourceInterface::CONDITION_AND)
 {
     switch ($condition) {
         case DataSourceInterface::CONDITION_AND:
             $this->queryBuilder->andWhere($expression);
             break;
         case DataSourceInterface::CONDITION_OR:
             $this->queryBuilder->orWhere($expression);
             break;
     }
 }
開發者ID:loic425,項目名稱:Sylius,代碼行數:14,代碼來源:DataSource.php

示例3: addQueryFilter

 private function addQueryFilter(QueryBuilder $query, $filter)
 {
     $expr = $query->expr();
     /*$query->orWhere($expr->eq('entity.id', ':filter_int'));*/
     $query->orWhere($expr->like('entity.code', ':filter_str'));
     $query->orWhere($expr->like('entity.oName', ':filter_str'));
     $query->orWhere($expr->like('entity.dName', ':filter_str'));
     /*$query->setParameter('filter_int', $filter);*/
     $query->setParameter('filter_str', '%' . $filter . '%');
     return $query;
 }
開發者ID:EPICUB,項目名稱:R2RioBundle,代碼行數:11,代碼來源:R2SearchRequestRepository.php

示例4: search

 /**
  * Quick search
  * 
  * @return \ZfTable\Source\DoctrineQueryBuilder
  */
 protected function search()
 {
     if ($search = $this->getParamAdapter()->getQuickSearch()) {
         foreach ($this->getTable()->getHeaders() as $k => $v) {
             $column = isset($v['column']) ? $v['column'] : $k;
             if (isset($v['tableAlias'])) {
                 $this->query->orWhere($this->query->expr()->like($v['tableAlias'] . '.' . $column, "'%" . $search . "%'"));
             }
         }
     }
     return $this;
 }
開發者ID:p21sistemas,項目名稱:ZfTable,代碼行數:17,代碼來源:DoctrineQueryBuilder.php

示例5: addRestriction

 /**
  * Adds a new WHERE or HAVING restriction depends on the given parameters.
  *
  * @param mixed  $restriction The restriction to add.
  * @param string $condition   The condition.
  *                            Can be FilterUtility::CONDITION_OR or FilterUtility::CONDITION_AND.
  * @param bool   $isComputed  Specifies whether the restriction should be added to the HAVING part of a query.
  */
 public function addRestriction($restriction, $condition, $isComputed = false)
 {
     $restriction = $this->qbTools->replaceAliasesWithFields($restriction);
     if ($condition === FilterUtility::CONDITION_OR) {
         if ($isComputed) {
             $this->qb->orHaving($restriction);
         } else {
             $this->qb->orWhere($restriction);
         }
     } else {
         if ($isComputed) {
             $this->qb->andHaving($restriction);
         } else {
             $this->qb->andWhere($restriction);
         }
     }
 }
開發者ID:Maksold,項目名稱:platform,代碼行數:25,代碼來源:OrmFilterDatasourceAdapter.php

示例6: whereToPublish

 private function whereToPublish(QueryBuilder $builder)
 {
     $builder->where('r.published = :published');
     $builder->setParameter('published', false);
     $builder->orWhere('p.modified = :modified');
     $builder->setParameter('modified', true);
     return $this;
 }
開發者ID:stmolivier,項目名稱:PathBundle,代碼行數:8,代碼來源:PathRepository.php

示例7: addRestriction

 /**
  * Adds a new WHERE or HAVING restriction depends on the given parameters.
  *
  * @param mixed  $restriction The restriction to add.
  * @param string $condition   The condition.
  *                            Can be FilterUtility::CONDITION_OR or FilterUtility::CONDITION_AND.
  * @param bool   $isComputed  Specifies whether the restriction should be added to the HAVING part of a query.
  */
 public function addRestriction($restriction, $condition, $isComputed = false)
 {
     if ($this->fixComparison($restriction, $condition)) {
         return;
     }
     if ($condition === FilterUtility::CONDITION_OR) {
         if ($isComputed) {
             $this->qb->orHaving($restriction);
         } else {
             $this->qb->orWhere($restriction);
         }
     } else {
         if ($isComputed) {
             $this->qb->andHaving($restriction);
         } else {
             $this->qb->andWhere($restriction);
         }
     }
 }
開發者ID:a2xchip,項目名稱:pim-community-dev,代碼行數:27,代碼來源:OrmFilterDatasourceAdapter.php

示例8: _multiFilter

 /**
  * Multiple filtering
  *
  * @param array $rules   array of rules fore multiple filtering
  * @param array $options array of search options
  *
  * @return void
  */
 protected function _multiFilter($rules, $options = array())
 {
     $boolean = strtoupper($options['boolean']);
     foreach ($rules as $rule) {
         if ($boolean == 'OR') {
             $this->_qb->orWhere($this->getService()->getAlias() . '.' . $rule['field'] . ' ' . str_replace('?', ':' . $rule['field'], $this->_operator[$rule['expression']]));
         } else {
             $this->_qb->andWhere($this->getService()->getAlias() . '.' . $rule['field'] . ' ' . str_replace('?', ':' . $rule['field'], $this->_operator[$rule['expression']]));
         }
         $this->_qb->setParameter($rule['field'], $this->_setWildCardInValue($rule['expression'], $rule['value']));
     }
 }
開發者ID:kdrezo,項目名稱:zf2-datagrid,代碼行數:20,代碼來源:ORMQueryAdapter.php

示例9: applyInheritanceActivity

 /**
  * Apply to given query builder object additional conditions
  * for integrate activity lists from inheritance targets
  *
  * @param QueryBuilder $qb
  * @param string  $entityClass
  * @param integer $entityId
  */
 public function applyInheritanceActivity(QueryBuilder $qb, $entityClass, $entityId)
 {
     if (!$this->hasInheritances($entityClass)) {
         return;
     }
     $inheritanceTargets = $this->getInheritanceTargetsRelations($entityClass);
     foreach ($inheritanceTargets as $key => $inheritanceTarget) {
         $alias = 'ta_' . $key;
         $qb->leftJoin('activity.' . $inheritanceTarget['targetClassAlias'], $alias);
         $qb->orWhere($qb->expr()->andX($qb->expr()->andX($qb->expr()->in($alias . '.id', $this->getSubQuery($inheritanceTarget['targetClass'], $inheritanceTarget['path'], $entityId, $key)->getDQL()))));
     }
 }
開發者ID:Maksold,項目名稱:platform,代碼行數:20,代碼來源:ActivityInheritanceTargetsHelper.php

示例10: consultaContiene

 /**
  * @param \Doctrine\ORM\Query|\Doctrine\ORM\QueryBuilder $query
  * @param array $array
  * @param string $contiene
  * @return \Doctrine\ORM\Query|\Doctrine\ORM\QueryBuilder
  */
 public function consultaContiene($query, $array, $contiene)
 {
     if ($contiene != "") {
         $fields = array_keys($this->getClassMetadata()->fieldNames);
         $alias = $query->getRootAlias();
         $count = 0;
         foreach ($array as $field) {
             $fieldMapping = $this->getClassMetadata()->getFieldForColumn($field);
             $where = sprintf("UPPER(%s.%s) LIKE :condicion", $alias, $fieldMapping);
             if ($count == 0) {
                 $query->andWhere($where);
             } else {
                 $query->orWhere($where);
             }
             $count++;
         }
         $query->setParameter("condicion", "%" . strtoupper($contiene) . "%");
     }
     return $query;
 }
開發者ID:uvillazon,項目名稱:symfonysecuriy,代碼行數:26,代碼來源:BaseRepository.php

示例11: addWhere

 /**
  * Adiciona condição
  * @param \Doctrine\ORM\QueryBuilder $queryBuilder
  * @param \Core_Dto_Search $dto
  */
 protected function addWhere(\Doctrine\ORM\QueryBuilder &$queryBuilder, \Core_Dto_Search $dto)
 {
     $isDate = FALSE;
     $dataSearch = strtotime($dto->getDataSearch());
     if (checkdate(date('m', $dataSearch), date('d', $dataSearch), date('Y', $dataSearch))) {
         $isDate = TRUE;
         $newDate = date('Y-m-d', $dataSearch);
         $queryBuilder->andWhere('vcm.dataCriacao = :data')->setParameter('data', $newDate);
         $queryBuilder->orWhere('vcm.prazo = :data')->setParameter('data', $newDate);
     }
     if (!$isDate && $dto->getDataSearch() != '') {
         $query = mb_strtolower($dto->getDataSearch(), 'UTF-8');
         $queryBuilder->andWhere('(LOWER(vcm.tipo) like :query)');
         $queryBuilder->orWhere('(LOWER(vcm.origem) like :query)');
         $queryBuilder->orWhere('(LOWER(vcm.assunto) like :query)');
         $queryBuilder->orWhere('(LOWER(vcm.autor) like :query)');
         $queryBuilder->setParameter('query', '%' . $query . '%');
     }
 }
開發者ID:sgdoc,項目名稱:sgdoce-codigo,代碼行數:24,代碼來源:Artefato.php

示例12: classicLikeComparison

 /**
  * Create a LIKE comparison with entity texts colunms.
  *
  * @param string                  $pattern
  * @param DoctrineORMQueryBuilder $qb
  * @param string                  $alias
  */
 protected function classicLikeComparison($pattern, \Doctrine\ORM\QueryBuilder &$qb, $alias = "obj")
 {
     /*
      * get fields needed for a search
      * query
      */
     $metadatas = $this->_em->getClassMetadata($this->getEntityName());
     $criteriaFields = [];
     $cols = $metadatas->getColumnNames();
     foreach ($cols as $col) {
         $field = $metadatas->getFieldName($col);
         $type = $metadatas->getTypeOfField($field);
         if (in_array($type, $this->searchableTypes) && $field != 'folder' && $field != 'childrenOrder' && $field != 'childrenOrderDirection') {
             $criteriaFields[$field] = '%' . strip_tags($pattern) . '%';
         }
     }
     foreach ($criteriaFields as $key => $value) {
         $qb->orWhere($qb->expr()->like($alias . '.' . $key, $qb->expr()->literal($value)));
     }
 }
開發者ID:QuangDang212,項目名稱:roadiz,代碼行數:27,代碼來源:EntityRepository.php

示例13: orWhere

 /**
  * {@inheritdoc}
  */
 public function orWhere($where)
 {
     $this->queryBuilder->orWhere($where);
     return $this;
 }
開發者ID:blazarecki,項目名稱:lug,代碼行數:8,代碼來源:DataSourceBuilder.php

示例14: buildQueryAutoCompleteTerm

 protected function buildQueryAutoCompleteTerm(array $fields, $term)
 {
     $qb = new QueryBuilder($this->_em);
     $qb->select('e')->from($this->_entityName, 'e');
     if (count($fields) > 0 && $term != "") {
         // term in quotes bedeutet wörtliche suche
         if (\Psc\Preg::match($term, '/^\\s*("|\')(.*)("|\')\\s*$/', $m)) {
             $term = $m[2];
             foreach ($fields as $field) {
                 $qb->orWhere('e.' . $field . ' = ?1 ');
             }
             $qb->setParameter(1, $term);
         } else {
             /* normale suche */
             foreach ($fields as $field) {
                 $qb->orWhere('e.' . $field . ' = ?1 ');
                 for ($i = 2; $i <= 4; $i++) {
                     $qb->orWhere('e.' . $field . ' LIKE ?' . $i);
                 }
             }
             $qb->setParameter(1, $term);
             $qb->setParameter(2, '%' . $term);
             $qb->setParameter(3, '%' . $term . '%');
             $qb->setParameter(4, $term . '%');
         }
     }
     return $qb;
 }
開發者ID:pscheit,項目名稱:psc-cms,代碼行數:28,代碼來源:EntityRepository.php

示例15: getDatatables

 /**
  * @param QueryBuilder $qb
  * @param array        $params
  *
  * @return array
  * @throws \Exception
  */
 public function getDatatables(QueryBuilder $qb, array $params)
 {
     if ($this->getAColumns() != '' && $this->getAColumnsArray() != '') {
         if ($_GET['sSearch'] != "") {
             for ($i = 0; $i < count($this->getAColumns()); $i++) {
                 if ($this->getAColumns()[$i]['type'] == "string") {
                     $qb->orWhere("LOWER(remove_accents(" . $this->getAColumns()[$i]['campo'] . ")) LIKE LOWER(remove_accents(:busca" . $i . "))")->setParameter("busca" . $i, '%' . $params['sSearch'] . '%');
                 } else {
                     if (is_int($params['sSearch'])) {
                         $qb->orWhere($this->getAColumns()[$i]['campo'] . " = '" . $params['sSearch'] . "'");
                     }
                 }
             }
         }
         // Select total
         $stmt = $this->getEntityManager()->getConnection()->prepare("SELECT count(a) FROM (:sql) AS a")->setParameter("sql", $this->get_raw_sql($qb));
         $stmt->execute();
         if (isset($params['iSortCol_0'])) {
             $primeiro = true;
             for ($i = 0; $i < intval($params['iSortingCols']); $i++) {
                 if ($params['bSortable_' . intval($params['iSortCol_' . $i])] == "true") {
                     if ($primeiro) {
                         $primeiro = false;
                         $qb->orderBy($this->getAColumns()[intval($params['iSortCol_' . $i])]['campo'], $params['sSortDir_' . $i]);
                     } else {
                         $qb->add($this->getAColumns()[intval($params['iSortCol_' . $i])]['campo'], $params['sSortDir_' . $i]);
                     }
                 }
             }
         }
         for ($i = 0; $i < count($this->getAColumns()); $i++) {
             if ($_GET['bSearchable_' . $i] == "true" && $params['sSearch_' . $i] != '') {
                 if ($this->getAColumns()[$i]['type'] == "string") {
                     $qb->orWhere("LOWER(remove_accents(" . $this->getAColumns()[$i]['campo'] . ")) LIKE LOWER(remove_accents(:busca" . $i . "))")->setParameter("busca" . $i, '%' . $params['sSearch_' . $i] . '%');
                 } else {
                     if (is_int($params['sSearch'])) {
                         $qb->andWhere($this->getAColumns()[$i]['campo'] . " = '" . $params['sSearch_' . $i] . "'");
                     }
                 }
             }
         }
         $qb->setMaxResults($params['iDisplayLength']);
         $qb->setFirstResult($params['iDisplayStart']);
         $rows = array();
         foreach ($qb->getQuery()->getResult() as $key => $value) {
             $aRow = $value->toArray();
             $row = array();
             for ($i = 0; $i < count($this->getAColumns()); $i++) {
                 if (isset($this->getAColumnsArray()[$i]['html'])) {
                     $html = $this->getAColumnsArray()[$i]['html'];
                     foreach ($aRow as $key => $value) {
                         $html = str_replace("{" . $key . "}", $value, $html);
                     }
                     $row[] = $html;
                 } else {
                     $row[] = $aRow[$this->getAColumnsArray()[$i]['campo']];
                 }
             }
             $rows[] = $row;
         }
         $total = $stmt->fetchAll()[0]['count'];
         $output = array("sEcho" => $params['sEcho'], "iTotalRecords" => $total, "iTotalDisplayRecords" => $total, "iDisplayLength" => $params['iDisplayLength'], "aaData" => $rows);
         return $output;
     } else {
         throw new \Exception("The value(getAColumns, getAColumnsArray) is required", 1);
     }
 }
開發者ID:lzerma,項目名稱:datatables-doctrine,代碼行數:74,代碼來源:DefaultRepository.php


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