繁体   English   中英

使用order_by和limit CodeIgniter在10个结果中选择5个随机结果?

[英]Select 5 random results in 10 with order_by & limit CodeIgniter?

我有一张有500个结果的表。

我需要按带DESC选项的Players进行订购,然后限制10个结果,并选择10个具有CodeIgniter的结果。

我有的:

public function getServers(){
    $this->db2->from('server');
    $this->db2->order_by("players", "desc");
    $this->db2->limit(5);

    $query  = $this->db2->get();

    if ($query->num_rows() > 0) {
        foreach ($query->result() as $row) {
            $data[] = $row;
        }
        return $data;
    }
    return false;
}

如果我对您的理解正确,您想选择数据库中排名前10位的结果,按列播放器的降序排列,然后随机选择其中5个?

只需将代码的一行更改为:

 $this->db2->limit(10);

然后调用如下方法:

$my_random_five = array_rand($this->getServers(), 5);

然后还要考虑使用http://php.net/manual/en/function.mt-rand.php

您的代码应类似于上面标记所建议的内容

            $my_random_five = array_rand($this->getServers(), 5);
            public function getServers(){
                $this->db2->from('server');
                $this->db2->order_by("players", "desc");
                $this->db2->limit(10);
                $query  = $this->db2->get();
                if ($query->num_rows() > 0) {
                    foreach ($query->result() as $row) {
                        $data[] = $row;
                    }
                    return $data;
                }
                return false;
            }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM