如何在Laravel框架中使用Eloquent或Fluent选择随机行?
我知道,通过使用SQL,您可以按RAND()进行排序。但是,我希望获得随机行,而不是在初始查询之前对记录的数量进行计数。
什么好主意吗?
如何在Laravel框架中使用Eloquent或Fluent选择随机行?
我知道,通过使用SQL,您可以按RAND()进行排序。但是,我希望获得随机行,而不是在初始查询之前对记录的数量进行计数。
什么好主意吗?
当前回答
在Laravel 4和5中,order_by被orderBy取代
所以,它应该是:
User::orderBy(DB::raw('RAND()'))->get();
其他回答
Laravel有一个内置的方法来打乱结果的顺序。
以下是文档中的一段话:
shuffle()
shuffle方法随机洗牌集合中的项:
$collection = collect([1, 2, 3, 4, 5]);
$shuffled = $collection->shuffle();
$shuffled->all();
// [3, 2, 5, 1, 4] - (generated randomly)
您可以在这里看到文档。
我宁愿先说明,否则就失败:
$collection = YourModelName::inRandomOrder()
->firstOrFail();
你可以使用:
ModelName::inRandomOrder()->first();
试试这段代码!工作原理:
User::orderBy(DB::raw('RAND()'))->get();
还有whereRaw('RAND()')做同样的事情,然后你可以chain ->get()或->first(),甚至疯狂地添加->paginate(int)。