我经常在我的模型和行为中创建小函数,为CakePHP中查找操作的array
添加额外条件,我一直在想实现这些函数的三种可能方法。它似乎总是归结为三种可能的代码模式。
我将使用一个名为limitErrorCount
的函数来演示这三种模式,该函数将为查找查询添加一个额外的规则。
模式#1:参数和返回
public function limitErrorCount(array $conditions)
{
$conditions['AND'][] = 'Document.errors <'=>10;
return $conditions;
}
$conditions = array(....);
$conditions = limitErrorCount($conditions);
$records = $this->find('all',$conditions);
模式#2:通过参考
public function limitErrorCount(array &$conditions)
{
$conditions['AND'][] = 'Document.errors <'=>10;
return $conditions;
}
$conditions = array(....);
limitErrorCount($conditions);
$records = $this->find('all',$conditions);
模式#3:返回并合并
public function limitErrorCount()
{
$conditions = array('AND'=>array('Document.errors <'=>10));
return $conditions;
}
$conditions = array(....);
$conditions = Hash::merge($conditions,limitErrorCount());
$records = $this->find('all',array('conditions'=>$conditions));
这三种模式都有效。
我想知道哪种方法是三种方法中最好的,也许还有一些PHP专家对为什么它更好的见解。
好主意,我希望看到它以一种类似jQuery 的链式方式实现
$cnd = $this->Document->filterFreshOnes()->filterStarred()->filterByDaysAge('3');
$res = $this->Document->find('all', array('conditions'=>$cnd);
但这需要将其保存在模型变量中,如果您忘记已经有一些过滤器,这可能会适得其反;(