如何在Laravel框架中使用Eloquent或Fluent选择随机行?

我知道,通过使用SQL,您可以按RAND()进行排序。但是,我希望获得随机行,而不是在初始查询之前对记录的数量进行计数。

什么好主意吗?


当前回答

对于Laravel 5.2 >=

使用Eloquent方法:

inRandomOrder()

可以使用inRandomOrder方法对查询结果进行随机排序。例如,你可以使用这个方法获取一个随机用户:

$randomUser = DB::table('users')
            ->inRandomOrder()
            ->first();

来自docs: https://laravel.com/docs/5.2/queries#ordering-grouping-limit-and-offset

其他回答

还有whereRaw('RAND()')做同样的事情,然后你可以chain ->get()或->first(),甚至疯狂地添加->paginate(int)。

你可以使用:

ModelName::inRandomOrder()->first();

使用Laravel函数

ModelName::inRandomOrder()->first();

在你的模型中添加这个:

public function scopeRandomize($query, $limit = 3, $exclude = [])
{
    $query = $query->whereRaw('RAND()<(SELECT ((?/COUNT(*))*10) FROM `products`)', [$limit])->orderByRaw('RAND()')->limit($limit);
    if (!empty($exclude)) {
        $query = $query->whereNotIn('id', $exclude);
    }
    return $query;
}

然后是route/controller

$data = YourModel::randomize(8)->get();

对于Laravel 5.2 >=

使用Eloquent方法:

inRandomOrder()

可以使用inRandomOrder方法对查询结果进行随机排序。例如,你可以使用这个方法获取一个随机用户:

$randomUser = DB::table('users')
            ->inRandomOrder()
            ->first();

来自docs: https://laravel.com/docs/5.2/queries#ordering-grouping-limit-and-offset