我知道Cake HABTM协会在最好的时候都很棘手,但我似乎让自己的生活更加艰难......
如果我想从db中返回一个随机项,我可以在Item模型中按如下方式执行:
$random = $this->find('first', array(
'order' => 'rand()'
));
如果我想找到某个类别中的所有项目(其中Item与类别有HABTM关系),我知道我可以通过$ this-> Categories-> find获得结果集。 / p>
我的问题是:如何将两者结合起来,以便我可以返回属于指定类别的随机项?有什么简单的方法吗? (如果没有,我会很乐意采取任何建议,只要它有效;)
ETA:我可以通过Containable获得一些方法,也许:说我添加了行
'contain' => array('Categories'=>array('conditions'=>array('Categories.id'=>1))),
然后Item结果我不想带回一个空的Categories数组,以区别于“好”的项目。但实际上我不希望所有项目结果都归还......
ETA(2):如果“类别”数组为空(感谢http://nuts-and-bolts-of-cakephp.com/2008/08/06/filtering-results-returned-by-containable-behavior/提示),我可以通过在afterFind中取消设置结果来获得解决方法,然后让我的随机查找功能不放弃直到得到结果:
while (!is_array($item)) {
$item = $this->random($cat);
}
但是,呃,这可能是笨蛋吗?无论如何,是时候让我停止编辑我的问题,然后离开并在上面睡觉吧!
答案 0 :(得分:4)
试试这个:
<?php
$this->Item->bindModel(array('hasOne' => array('ItemsCategory')));
$random = $this->Item->find('all', array(
'order' => 'rand()',
'conditions' => array('ItemsCategory.category_id' => '1')
));
?>