我有一个返回 Doctrine_Collection 的方法,带有一个whereIn()
子句:
public function getByValues($values)
{
if (!is_array($values))
throw new sfException('Wrong parameter type. Excepted array.');
return Doctrine_Query::create()
->from('Anomaly a')
->whereIn('a.value', $values);
}
但是,当$values
是一个空数组时,此方法返回AnomalyTable 中的所有行。这不是意外的行为,如 Doctrine 文档中所述,并写在此处:Doctrine where in with Doctrine_Query
但是,当是一个空数组时,我想返回一个空Doctrine_Collection
而不是我的查询结果。$values
关于我如何做到这一点的任何想法?
谢谢 =)
编辑:
添加一个不可能的子句,like->where('1=0')
可以解决问题,但它是对数据库服务器的不必要请求。有人有更好的主意吗?