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

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

什么好主意吗?


当前回答

在Laravel 4和5中,order_by被orderBy取代

所以,它应该是:

User::orderBy(DB::raw('RAND()'))->get();

其他回答

试试这段代码!工作原理:

  User::orderBy(DB::raw('RAND()'))->get();

在Laravel 4和5中,order_by被orderBy取代

所以,它应该是:

User::orderBy(DB::raw('RAND()'))->get();

你也可以使用order_by方法,如:

Posts::where_status(1)->order_by(DB::raw(''),DB::raw('RAND()')); 

这是一个有点奇怪的用法,但是有用。

编辑:正如@Alex所说,这种用法更简洁,也有效:

Posts::where_status(1)->order_by(DB::raw('RAND()'));

在你的模型中添加这个:

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();

我宁愿先说明,否则就失败:

$collection = YourModelName::inRandomOrder()
  ->firstOrFail();