如何在 CreatequeryBuilder (symfony) 的 Setparameter 中传递间隔



使用createqueryBuilder,在它的Setparameter中,我想传递一个区间,而不仅仅是一个变量或一个数字。我想传递一个像 [$min,$max] 这样的间隔,其中 min 和 max 是变量而不是数字。这是我到目前为止所做的:

$queryBuilder = $em->getRepository('MainBundle:Annonce')->createQueryBuilder('bp')
->where('bp.categorie =:cat1' )
->setParameter('cat1',[$min,$max])

但它不起作用,也不是有效的代码.任何帮助将不胜感激:)

你可以做...

如果要使用BETWEENf.e:

$qb->where('bp.categorie BETWEEN :minValue AND :maxValue')
->setParameter('minValue', $min)
->setParameter('maxValue', $max)

您还可以:

$qb->where('bp.categorie >= :minValue')
->andWhere('bp.categorie <= :maxValue')
->setParameter('minValue', $min)
->setParameter('maxValue', $max)

您也可以按如下方式使用 Expr 帮助程序类: $qb->where( $qb->expr()->between('bp.categorie', ':minVal', ':maxVal')) ->setParameter('minVal', $min) ->setParameter('maxVal', $max)

在这样的构造中,你可以将参数直接传递给 between(( 方法:

$qb->expr()->between('bp.categorie', $min, $max)

最新更新