我正在尝试在我的一张表上进行查找,并且我正在动态地将条件添加到从一个模型到另一个模型的 hasMany 关系中。一切正常,除了 Cake 不会将组条件应用于查询。如果我复制生成的查询并在 MySQL 中运行它并添加我的 Group By 条件,它会很好地工作。我尝试了很多方法,但都无济于事,而我现在的设置方式就像 Cake 文档中的 Find 页面告诉我设置组一样。你可以在下面找到我是如何做到的:
$this->Project->hasMany['ProjectTime']['conditions'] = array('user_id'=>$this->Auth->user('id'), 'date_entry >= '.$firstDay.' AND date_entry <= '.$lastDay);
$this->Project->hasMany['ProjectTime']['order'] = array('date_entry ASC');
$this->Project->hasMany['ProjectTime']['group'] = 'ProjectTime.date_entry';
$this->Project->hasMany['ProjectTime']['fields'] = array('ProjectTime.date_entry, ProjectTime.user_id, ProjectTime.project_id, SUM(ProjectTime.duration) AS durationTotal');
$result = $this->Project->find('all', array('conditions'=>array('Project.id IN (' . implode(",", $projectTimeArray) . ')')));
我已经尝试将它直接放在模型中的 hasMany 数组中 - 什么都没有。我试过在组周围放置一个数组 - 没有。我真的很难过,所以如果有人可以提供帮助,我将不胜感激。