加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

cakephp – Cake HABTM查询,按Rand排序()

发布时间:2020-12-13 17:04:58 所属栏目:PHP教程 来源:网络整理
导读:我知道Cake HABTM协会在最好的时候都很棘手,但我似乎让自己的生活变得更加艰难…… 如果我想从db中返回一个随机项,我可以在Item模型中按如下方式执行: $random = $this-find('first',array( 'order' = 'rand()')); 如果我想找到某个类别中的所有项目(其中It
我知道Cake HABTM协会在最好的时候都很棘手,但我似乎让自己的生活变得更加艰难……

如果我想从db中返回一个随机项,我可以在Item模型中按如下方式执行:

$random = $this->find('first',array(
    'order' => 'rand()'
));

如果我想找到某个类别中的所有项目(其中Item与类别有HABTM关系),我知道我可以通过$this-> Categories-> find获得结果集.

我的问题是:如何将两者结合起来,以便我可以返回属于指定类别的随机项?有什么简单的方法吗? (如果没有,我会很乐意采取任何建议,只要它有效;)

ETA:我可以通过Containable获得一些方法,也许:说我添加了这条线

'contain' => array('Categories'=>array('conditions'=>array('Categories.id'=>1))),

然后Item结果我不想带回一个空的Categories数组,以区别于“好”的项目.但实际上我不希望所有项目结果都归还…

ETA(2):我可以通过在afterFind中取消设置结果来解决方法,如果Categories数组为空(感谢http://nuts-and-bolts-of-cakephp.com/2008/08/06/filtering-results-returned-by-containable-behavior/的提示),然后让我的随机查找功能在结果得到之前不放弃:

while (!is_array($item)) {
    $item = $this->random($cat);
}

但是,这可能是笨重的吗?无论如何,时间让我停止编辑我的问题,然后离开并在它上面睡觉!

解决方法

试试这个:

<?php
$this->Item->bindModel(array('hasOne' => array('ItemsCategory')));
$random = $this->Item->find('all',array(
  'order' => 'rand()','conditions' => array('ItemsCategory.category_id' => '1')
  ));
?>

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读