【发布时间】:2015-10-04 18:36:51
【问题描述】:
我想使用带有两列检查的 WHERE IN 语句更新 db 中的多条记录。
Pure MySql 原始查询看起来像这样.. 它可以工作:
UPDATE poll_quota q SET q.count = q.count+1 WHERE q.form_id=14 AND ((q.field_id,q.value) IN (('A',1),('B',1)))
我的代码:
$this->createQueryBuilder("q")
->update()
->set("q.count","q.count+1")
->where("q.form_id=:form_id")
->andWhere("((q.field_id,q.value) IN (:wherein))")
->setParameter(":form_id",$form_id)
->setParameter(":wherein",$where_in)
->getQuery()
->execute()
;
输出:
[Syntax Error] line 0, col 103: Error: Expected Doctrine\ORM\Query\Lexer::T_CLOSE_PARENTHESIS, got ','
[1/2] QueryException: UPDATE Edge\PollBundle\Entity\Quota q SET q.count = q.count+1 WHERE q.form_id=:form_id AND ((q.field_id,q.value) IN (:wherein)) +
尝试这样做,也不起作用:
[...]->andWhere("((q.field_id,q.value) IN ({$where_in}))")
$where_in 包含这样的字符串:
"('A',1),('B',1)"
【问题讨论】:
-
你不能只用
->andWhere("q.field_id IN (:wherein)")->andWhere("q.value IN (:wherein)")吗? -
脚本仅更新选定的 field_id 和 value 对。在这种情况下,单独的 IN 语句将不起作用。
-
不幸的是,我认为我并不真正了解脚本的作用/将要做什么。
标签: php mysql symfony doctrine where-in