如何在Laravel框架中使用Eloquent或Fluent选择随机行?

我知道,通过使用SQL,您可以按RAND()进行排序。但是,我希望获得随机行,而不是在初始查询之前对记录的数量进行计数。

什么好主意吗?


当前回答

我宁愿先说明,否则就失败:

$collection = YourModelName::inRandomOrder()
  ->firstOrFail();

其他回答

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

所以,它应该是:

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

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

// 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(); 

我宁愿先说明,否则就失败:

$collection = YourModelName::inRandomOrder()
  ->firstOrFail();

以下是我如何在我的一个项目中获得雄辩的随机结果:

$products           =  Product::inRandomOrder()->limit(10);

10 -随机记录的数量。

试试这段代码!工作原理:

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