如何在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

其他回答

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

所以,它应该是:

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

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

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

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

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

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

Posts::where_status(1)->order_by(DB::raw('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

我有成千上万的记录表,所以我需要一些快速。这是我的伪随机行代码:

// count all rows with flag active = 1
$count = MyModel::where('active', '=', '1')->count(); 

// get random id
$random_id = rand(1, $count - 1);  

// get first record after random id
$data = MyModel::where('active', '=', '1')->where('id', '>', $random_id)->take(1)->first();