我有一系列产品ID.我必须这样查询:
SELECT * FROM products WHERE pid IN (1, 2, 8, 4, ...) // etc
Run Code Online (Sandbox Code Playgroud)
我的变量$ pids中有我的id.
$qb = $em->createQueryBuilder();
$query = $qb->select('p.pid')
->from('SRC\MainBundle\Entity\Product', 'p')
->where('p.name IN :pids') // error is HERE
->setParameter('pids', $pids)
->getQuery();
Run Code Online (Sandbox Code Playgroud)
不行.我收到一个错误:
[Syntax Error] line 0, col 66: Error: Expected Doctrine\ORM\Query\Lexer::T_OPEN_PARENTHESIS, got ':pids'
Run Code Online (Sandbox Code Playgroud)
zer*_*kms 11
如果你尝试怎么办?
->where('p.name IN (:pids)') // error is HERE
Run Code Online (Sandbox Code Playgroud)
它明确告诉你它预期parentheses但得到placeholder
| 归档时间: |
|
| 查看次数: |
4432 次 |
| 最近记录: |