如何在Laravel框架中使用Eloquent或Fluent选择随机行?
我知道,通过使用SQL,您可以按RAND()进行排序。但是,我希望获得随机行,而不是在初始查询之前对记录的数量进行计数。
什么好主意吗?
如何在Laravel框架中使用Eloquent或Fluent选择随机行?
我知道,通过使用SQL,您可以按RAND()进行排序。但是,我希望获得随机行,而不是在初始查询之前对记录的数量进行计数。
什么好主意吗?
当前回答
您可以轻松地使用此命令:
//问题:模型的名称 //从DB中抽取10行
$questions = Question::orderByRaw('RAND()')->take(10)->get();
其他回答
你也可以使用order_by方法,如:
Posts::where_status(1)->order_by(DB::raw(''),DB::raw('RAND()'));
这是一个有点奇怪的用法,但是有用。
编辑:正如@Alex所说,这种用法更简洁,也有效:
Posts::where_status(1)->order_by(DB::raw('RAND()'));
你可以使用:
ModelName::inRandomOrder()->first();
在Laravel 4和5中,order_by被orderBy取代
所以,它应该是:
User::orderBy(DB::raw('RAND()'))->get();
您可以轻松地使用此命令:
//问题:模型的名称 //从DB中抽取10行
$questions = Question::orderByRaw('RAND()')->take(10)->get();
还有whereRaw('RAND()')做同样的事情,然后你可以chain ->get()或->first(),甚至疯狂地添加->paginate(int)。