【问题标题】:How do I return a single random row from a model?如何从模型中返回单个随机行?
【发布时间】:2011-03-11 06:23:25
【问题描述】:

尝试从模型中获取单个随机行。这是我从网上提取的:

$this->Testimonial->findAll(null,null,'rand()',1,null,null);

很遗憾 findAll 在 cakephp 1.3 中不再存在

【问题讨论】:

    标签: cakephp-1.3


    【解决方案1】:
    $this->Quote->find('first', array('order' => array('rand()')))
    

    【讨论】:

      【解决方案2】:

      你可以试试这个:

      $count = $this->Testimonial->find('count');
      $this->Testimonial->find('first', array('conditions' => array('id' => rand(1,$count))));
      

      (这也不会检索“所有”结果)

      【讨论】:

      • 如果我的 ID 没有按顺序排列怎么办?
      • 那么您只需检索所有结果,然后随机选择一个,$find = $this->Model->find('all'); echo $find[rand(0,count($find))]['Model']['someName']
      • @Thomas:这会浪费大量资源,因为所有数据都必须从数据库放到 PHP 中,然后才能被丢弃。最好让数据库服务器处理正确数据集的挑选。
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-08-28
      • 2017-09-07
      • 1970-01-01
      • 2021-09-25
      • 2020-07-30
      • 2014-01-28
      相关资源
      最近更新 更多