使用createqueryBuilder,在它的Setparameter中,我想传递一个区间,而不仅仅是一个变量或一个数字。我想传递一个像 [$min,$max] 这样的间隔,其中 min 和 max 是变量而不是数字。这是我到目前为止所做的:
$queryBuilder = $em->getRepository('MainBundle:Annonce')->createQueryBuilder('bp')
->where('bp.categorie =:cat1' )
->setParameter('cat1',[$min,$max])
但它不起作用,也不是有效的代码.任何帮助将不胜感激:)
你可以做...
如果要使用BETWEEN
f.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)