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


PHP QueryBuilder::setParameters方法代碼示例

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


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

示例1: setUp

 public function setUp()
 {
     $this->queryConfig = new QueryConfig();
     $this->queryConfig->setLimit(5)->setSelect(array('t.a', 't.b', 't.c'))->setPage(2)->setOrderBy(array('t.d' => true, 't.e' => false))->addParameter('query', '%xxx%')->getConstraints()->add('LOWER(t.a) LIKE :query')->add('LOWER(t.c) LIKE :query');
     $this->queryBuilder = new QueryBuilderMock();
     $this->queryBuilder->from('Table', 't');
     if ($this->queryConfig->getConstraints()->count() > 0) {
         $this->queryBuilder->andWhere($this->queryConfig->getConstraints());
     }
     if (count($this->queryConfig->getParameters()) > 0) {
         $this->queryBuilder->setParameters($this->queryConfig->getParameters());
     }
     $this->dataProvider = new DataProvider();
 }
開發者ID:cwd,項目名稱:TableBundle,代碼行數:14,代碼來源:DataProviderTest.php

示例2: manipulateQuery

 public function manipulateQuery(QueryBuilder $query, $prefix = 'hv')
 {
     $query->where("{$prefix}.createdAt >= :startDate");
     $query->andWhere("{$prefix}.createdAt <= :endDate");
     $query->setParameters(['startDate' => $this->period->getStartDate(), 'endDate' => $this->period->getEndDate()]);
     return $query;
 }
開發者ID:piotrpasich,項目名稱:HighFiveSlackBundle,代碼行數:7,代碼來源:Period.php

示例3: setParameters

 /**
  * {@inheritdoc}
  */
 public function setParameters($parameters)
 {
     $this->parameters += $parameters;
     if ($this->qb instanceof QueryBuilder) {
         $this->qb->setParameters($this->parameters);
     }
     return $this;
 }
開發者ID:abdeldayem,項目名稱:pim-community-dev,代碼行數:11,代碼來源:Datasource.php

示例4: setParameters

 /**
 * Sets a collection of query parameters for the query being constructed.
 *
 * <code>
 *     $qb = $em->createQueryBuilder()
 *         ->select('u')
 *         ->from('User', 'u')
 *         ->where('u.id = :user_id1 OR u.id = :user_id2')
 *         ->setParameters(new ArrayCollection(array(
 *             new Parameter('user_id1', 1),
 *             new Parameter('user_id2', 2)
     )));
 * </code>
 *
 * Notice: This method overrides ALL parameters in Doctrine 2.3 and up.
 * We keep the old Doctrine < 2.3 behavior here for Shopware BC reasons,
 * however this will change in the future. Use {@link setParameter()}
 * instead or call {@link setParameters()} only once, or with all the
 * parameters.
 *
 * @param \Doctrine\Common\Collections\ArrayCollection|array $parameters The query parameters to set.
 * @return QueryBuilder This QueryBuilder instance.
 */
 public function setParameters($parameters)
 {
     $existingParameters = $this->getParameters();
     if (count($existingParameters) && is_array($parameters)) {
         return $this->addParameters($parameters);
     }
     return parent::setParameters($parameters);
 }
開發者ID:GerDner,項目名稱:luck-docker,代碼行數:31,代碼來源:QueryBuilder.php

示例5: removeExtraParameters

 /**
  * We update the query to count, get ids and fetch data, so, we can lost expected query builder parameters,
  * and we have to remove them
  *
  * @param QueryBuilder $qb
  */
 public static function removeExtraParameters(QueryBuilder $qb)
 {
     $parameters = $qb->getParameters();
     $dql = $qb->getDQL();
     foreach ($parameters as $parameter) {
         if (strpos($dql, ':' . $parameter->getName()) === false) {
             $parameters->removeElement($parameter);
         }
     }
     $qb->setParameters($parameters);
 }
開發者ID:javiersantos,項目名稱:pim-community-dev,代碼行數:17,代碼來源:QueryBuilderUtility.php

示例6: buildWhereClause

 /**
  * @param QueryBuilder $qb
  * @param Criteria $criteria
  */
 protected function buildWhereClause(QueryBuilder $qb, Criteria $criteria)
 {
     $values = array();
     foreach ($criteria as $key => $value) {
         if ($this->metadata->hasField($key) || $this->metadata->hasAssociation($key)) {
             $qb->andWhere('e.' . $key . ' = :' . $key);
             $values[$key] = $value;
         }
     }
     $qb->setParameters($values);
 }
開發者ID:stanlemon,項目名稱:rest-bundle,代碼行數:15,代碼來源:OrmRepositoryWrapper.php

示例7: buildQuery

 /**
  * Build a filter query.
  *
  * @param \Symfony\Component\Form\Form $form
  * @param \Doctrine\ORM\QueryBuilder $query
  * @return \Doctrine\ORM\QueryBuilder
  */
 public function buildQuery(Form $form, BaseQueryBuilder $query)
 {
     $this->query = $query;
     //$this->getPlatfornName();
     $group_child = $this->groupChild($form);
     foreach ($group_child as $field => $child) {
         if ($condition = $this->applyFilter($child, $field)) {
             $query->andWhere($condition);
         }
     }
     return $query->setParameters($this->parameters);
 }
開發者ID:zk2,項目名稱:admin-panel-bundle,代碼行數:19,代碼來源:QueryBuilder.php

示例8: fixUnusedParameters

 /**
  * Removes unused parameters from query builder
  *
  * @param QueryBuilder $qb
  */
 public function fixUnusedParameters(QueryBuilder $qb)
 {
     $dql = $qb->getDQL();
     $usedParameters = [];
     /** @var $parameter \Doctrine\ORM\Query\Parameter */
     foreach ($qb->getParameters() as $parameter) {
         if ($this->dqlContainsParameter($dql, $parameter->getName())) {
             $usedParameters[$parameter->getName()] = $parameter->getValue();
         }
     }
     $qb->setParameters($usedParameters);
 }
開發者ID:northdakota,項目名稱:platform,代碼行數:17,代碼來源:QueryBuilderTools.php

示例9: __wakeup

 /**
  * Recreate query builder and set state again.
  *
  * @return void
  */
 public function __wakeup()
 {
     if ($this->constraint !== NULL) {
         $this->queryBuilder->where($this->constraint);
     }
     if (is_array($this->orderings)) {
         foreach ($this->orderings as $propertyName => $order) {
             $this->queryBuilder->addOrderBy($this->queryBuilder->getRootAlias() . '.' . $propertyName, $order);
         }
     }
     if (is_array($this->joins)) {
         foreach ($this->joins as $joinAlias => $join) {
             $this->queryBuilder->leftJoin($join, $joinAlias);
         }
     }
     $this->queryBuilder->setFirstResult($this->offset);
     $this->queryBuilder->setMaxResults($this->limit);
     $this->queryBuilder->setParameters($this->parameters);
     unset($this->parameters);
 }
開發者ID:rekrut,項目名稱:typo3-extbase-doctrine2-extension,代碼行數:25,代碼來源:Query.php

示例10: applyMassActionParameters

 /**
  * Applies mass action parameters on the query builder
  *
  * @param QueryBuilder $qb
  * @param bool         $inset
  * @param array        $values
  */
 public function applyMassActionParameters($qb, $inset, $values)
 {
     if (!empty($values)) {
         $valueWhereCondition = $inset ? $qb->expr()->in($this->getAlias(), $values) : $qb->expr()->notIn($this->getAlias(), $values);
         $qb->andWhere($valueWhereCondition);
     }
     if (null !== $qb->getDQLPart('where')) {
         $whereParts = $qb->getDQLPart('where')->getParts();
         $qb->resetDQLPart('where');
         foreach ($whereParts as $part) {
             if (!is_string($part) || !strpos($part, 'entityIds')) {
                 $qb->andWhere($part);
             }
         }
     }
     $qb->setParameters($qb->getParameters()->filter(function ($parameter) {
         return $parameter->getName() !== 'entityIds';
     }));
     // remove limit of the query
     $qb->setMaxResults(null);
 }
開發者ID:ronanguilloux,項目名稱:CustomEntityBundle,代碼行數:28,代碼來源:CustomEntityRepository.php

示例11: filter

 public function filter(QueryBuilder $queryBuilder, $metadata, $option)
 {
     if (isset($option['where'])) {
         if ($option['where'] === 'and') {
             $queryType = 'andWhere';
         } elseif ($option['where'] === 'or') {
             $queryType = 'orWhere';
         }
     }
     if (!isset($queryType)) {
         $queryType = 'andWhere';
     }
     $orX = $queryBuilder->expr()->orX();
     $em = $queryBuilder->getEntityManager();
     $qb = $em->createQueryBuilder();
     foreach ($option['conditions'] as $condition) {
         $filter = $this->getFilterManager()->get(strtolower($condition['type']), array($this->getFilterManager()));
         $filter->filter($qb, $metadata, $condition);
     }
     $dqlParts = $qb->getDqlParts();
     $orX->addMultiple($dqlParts['where']->getParts());
     $queryBuilder->setParameters(new ArrayCollection(array_merge_recursive($queryBuilder->getParameters()->toArray(), $qb->getParameters()->toArray())));
     $queryBuilder->{$queryType}($orX);
 }
開發者ID:api-skeletons,項目名稱:zf-doctrine-orm-querybuilder,代碼行數:24,代碼來源:OrXFilter.php

示例12: prepareCndCommon

 /**
  * prepareCndCommon
  *
  * @param \Doctrine\ORM\QueryBuilder $queryBuilder QueryBuilder instance
  * @param string                     $value        Searchable value
  * @param string                     $fieldName    Searchable parameter name
  * @param boolean                    $exactCmp     Flag: use exact comparison (=) or 'LIKE' OPTIONAL
  * @param string                     $alias        Profile entity alias OPTIONAL
  *
  * @return void
  */
 protected function prepareCndCommon(\Doctrine\ORM\QueryBuilder $queryBuilder, $value, $fieldName, $exactCmp = true, $alias = 'p')
 {
     if (!empty($value)) {
         $queryBuilder->andWhere(sprintf('%s.%s %s', $alias, $fieldName, $exactCmp ? '= :' . $fieldName : 'LIKE :' . $fieldName));
         $queryBuilder->setParameters(array_merge($queryBuilder->getParameters(), array($fieldName => $exactCmp ? $value : '%' . $value . '%')));
     }
 }
開發者ID:kingsj,項目名稱:core,代碼行數:18,代碼來源:Profile.php

示例13: all

 /**
  *
  * @access public
  * @param  \Doctrine\ORM\QueryBuilder                   $qb
  * @param  Array                                        $parameters
  * @return \Doctrine\Common\Collections\ArrayCollection
  */
 public function all(QueryBuilder $qb, $parameters = array())
 {
     if (count($parameters)) {
         $qb->setParameters($parameters);
     }
     try {
         return $qb->getQuery()->getResult();
     } catch (\Doctrine\ORM\NoResultException $e) {
         return null;
     }
 }
開發者ID:nicolaskern,項目名稱:CCDNUserSecurityBundle,代碼行數:18,代碼來源:BaseGateway.php

示例14: addWhere


//.........這裏部分代碼省略.........
         // straight DQL string
         $qb->andWhere($where);
     } elseif (is_array($where) && count($where)) {
         // create where expression
         $whereExp = $qb->expr()->andx();
         $params = array();
         // index for the parameters
         $i = 0;
         // loop through all the clauses supplied
         foreach ($where as $col => $val) {
             if (is_array($val) && (!isset($val['value']) || is_string($val['value']) && strlen($val['value']) == 0) || is_string($val) && (!$val || strlen($val) == 0)) {
                 // skip if invalid value;
                 continue;
             }
             // check if we've been provided with an operator as well as a value
             if (!is_array($val)) {
                 $operator = Expr\Comparison::EQ;
                 $val = $val;
             } elseif (count($val) == 1) {
                 $operator = Expr\Comparison::EQ;
                 $val = end($val);
             } else {
                 $operator = isset($val['operator']) ? $val['operator'] : Expr\Comparison::EQ;
                 $val = array_key_exists('value', $val) ? $val['value'] : array();
             }
             // set the alias to the default
             $alias = $this->alias;
             // if col relates to a relation i.e. Role.id
             // then perform a join and set up the alias and column names
             if (strpos($col, '.') !== false) {
                 $parts = explode('.', $col);
                 $col = array_pop($parts);
                 $par = $this->alias;
                 foreach ($parts as $rel) {
                     $alias = strtolower($rel);
                     $jt = new Expr\Join(Expr\Join::LEFT_JOIN, $par . '.' . $rel, $alias);
                     if (!strpos($qb->getDql(), $jt->__toString()) !== false) {
                         $qb->leftJoin($par . '.' . $rel, $alias);
                     }
                     $par = $alias;
                 }
             }
             // process sets a little differently
             if (!is_array($val)) {
                 $val = array($val);
             }
             if ($operator == 'regexp') {
                 $whereExp->add("REGEXP(" . $alias . '.' . $col . ",'" . $val[0] . "') = 1");
             } else {
                 if ($operator == 'between') {
                     if (count($val) == 2) {
                         // $value should now be an array with 2 values
                         $expr = new Expr();
                         $from = is_int($val[0]) ? $val[0] : "'" . $val[0] . "'";
                         $to = is_int($val[1]) ? $val[1] : "'" . $val[1] . "'";
                         $stmt = $expr->between($alias . '.' . $col, $from, $to);
                         $whereExp->add($stmt);
                     }
                 } else {
                     if ($operator == 'is') {
                         $expr = new Expr();
                         $method = 'is' . ucfirst($val[0]);
                         if (method_exists($expr, $method)) {
                             $stmt = $expr->{$method}($alias . '.' . $col);
                             $whereExp->add($stmt);
                         }
                     } else {
                         // this holds the subquery for this field, each component being an OR
                         $subWhereExp = $qb->expr()->orX();
                         foreach ($val as $value) {
                             if ($value == null) {
                                 $cmpValue = 'NULL';
                             } else {
                                 $cmpValue = '?' . $i;
                                 // wrap LIKE values
                                 if ($operator == 'like') {
                                     $value = '%' . trim($value, '%') . '%';
                                 }
                                 // add the parameter value into the parameters stack
                                 $params[$i] = $value;
                                 $i++;
                             }
                             $comparison = new Expr\Comparison($alias . '.' . $col, $operator, $cmpValue);
                             $subWhereExp->add($comparison);
                         }
                         // add in the subquery as an AND
                         $whereExp->add($subWhereExp);
                     }
                 }
             }
         }
         // only add where expression if actually has parts
         if (count($whereExp->getParts())) {
             $qb->where($whereExp);
         }
         // set the params from the where clause above
         $qb->setParameters($params);
     }
     return $this;
 }
開發者ID:paul-crashley,項目名稱:ZucchiDoctrine,代碼行數:101,代碼來源:QueryBuilderTrait.php

示例15: buildInCondition

 /**
  * Build IN () condition
  *
  * @param \Doctrine\ORM\QueryBuilder $qb     Query builder
  * @param array                      $data   Hash array
  * @param string                     $prefix Placeholder prefix OPTIONAL
  *
  * @return array Keys for IN () function
  */
 public static function buildInCondition(\Doctrine\ORM\QueryBuilder $qb, array $data, $prefix = 'arr')
 {
     list($keys, $data) = static::prepareArray($data, $prefix);
     $qb->setParameters($data);
     return $keys;
 }
開發者ID:kingsj,項目名稱:core,代碼行數:15,代碼來源:Database.php


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