如何在Laravel框架中使用Eloquent或Fluent选择随机行?
我知道,通过使用SQL,您可以按RAND()进行排序。但是,我希望获得随机行,而不是在初始查询之前对记录的数量进行计数。
什么好主意吗?
如何在Laravel框架中使用Eloquent或Fluent选择随机行?
我知道,通过使用SQL,您可以按RAND()进行排序。但是,我希望获得随机行,而不是在初始查询之前对记录的数量进行计数。
什么好主意吗?
当前回答
试试这段代码!工作原理:
User::orderBy(DB::raw('RAND()'))->get();
其他回答
你可以使用:
ModelName::inRandomOrder()->first();
对于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
以下是我如何在我的一个项目中获得雄辩的随机结果:
$products = Product::inRandomOrder()->limit(10);
10 -随机记录的数量。
你也可以使用order_by方法,如:
Posts::where_status(1)->order_by(DB::raw(''),DB::raw('RAND()'));
这是一个有点奇怪的用法,但是有用。
编辑:正如@Alex所说,这种用法更简洁,也有效:
Posts::where_status(1)->order_by(DB::raw('RAND()'));
试试这段代码!工作原理:
User::orderBy(DB::raw('RAND()'))->get();