如何在Laravel框架中使用Elount或Fluent Select 随机行?
我知道通过使用SQL,您可以按RAND()进行排序.然而,我想让随机行without在初始查询之前对记录数进行计数.
有什么 idea 吗?
如何在Laravel框架中使用Elount或Fluent Select 随机行?
我知道通过使用SQL,您可以按RAND()进行排序.然而,我想让随机行without在初始查询之前对记录数进行计数.
有什么 idea 吗?
Laravel >= 5.2:
User::inRandomOrder()->get();
或者获取特定数量的记录
// 5 indicates the number of records
User::inRandomOrder()->limit(5)->get();
// get one random record
User::inRandomOrder()->first();
或对集合使用random方法:
User::all()->random();
User::all()->random(10); // The amount of items you wish to receive
Laravel 4.2.7-5.1:
User::orderByRaw("RAND()")->get();
Laravel 4.0-4.2.6:
User::orderBy(DB::raw('RAND()'))->get();
拉威尔3:
User::order_by(DB::raw('RAND()'))->get();
在MySQL随机行上判断100.Laravel 5.2支持这一点,对于旧版本,没有比使用RAW Queries更好的解决方案了.
edit 1:正如Double Gras所提到的,orderBy()不允许除ASC或DESC之外的任何内容,因为this发生了变化.我相应地更新了我的答案.
edit 2:Laravel 5.2最终为此实现了a wrapper function.它叫inRandomOrder().