Answers:
Laravel> = 5.2:
User::all()->random();
User::all()->random(10); // The amount of items you wish to receive
要么
User::inRandomOrder()->get();
或获取特定数量的记录
//5 indicates the number of records
User::inRandomOrder()->limit(5)->get();
Laravel 4.2.7-5.1:
User::orderByRaw("RAND()")->get();
Laravel 4.0-4.2.6:
User::orderBy(DB::raw('RAND()'))->get();
Laravel 3:
User::order_by(DB::raw('RAND()'))->get();
查看有关MySQL随机行的本文。Laravel 5.2支持这一点,对于较旧的版本,没有比使用RAW Queries更好的解决方案了。
编辑1:如Double Gras所述,由于此更改,orderBy()不允许ASC或DESC之后的任何其他内容。我相应地更新了我的答案。
编辑2: Laravel 5.2最终为此实现了包装函数。它称为inRandomOrder()。
'RANDOM()'
这样很好,
$model=Model::all()->random(1)->first();
您还可以在随机函数中更改参数以获取多个记录。
注意:如果您有大量数据,则不建议这样做,因为这将首先获取所有行,然后返回随机值。
tl; dr:如今已在Laravel中实现,请参见下面的“ edit 3”。
遗憾的是,截止到今天,->orderBy(DB::raw('RAND()'))
提出的解决方案有一些警告:
RANDOM()
更糟糕的是,由于此更改,此解决方案不再适用:
$direction = strtolower($direction) == 'asc' ? 'asc' : 'desc';
编辑:现在您可以使用orderByRaw()方法:->orderByRaw('RAND()')
。但是,这仍然不是DB不可知的。
FWIW,CodeIgniter实现了一个特殊的 RANDOM
排序方向,在构建查询时将其替换为正确的语法。而且它似乎很容易实现。看来我们有一个候选人可以改善Laravel :)
更新:这是关于GitHub 的问题,以及我的待处理的pull request。
编辑2:让我们切入正题。从Laravel 5.1.18开始,您可以将宏添加到查询构建器中:
use Illuminate\Database\Query\Builder;
Builder::macro('orderByRandom', function () {
$randomFunctions = [
'mysql' => 'RAND()',
'pgsql' => 'RANDOM()',
'sqlite' => 'RANDOM()',
'sqlsrv' => 'NEWID()',
];
$driver = $this->getConnection()->getDriverName();
return $this->orderByRaw($randomFunctions[$driver]);
});
用法:
User::where('active', 1)->orderByRandom()->limit(10)->get();
DB::table('users')->where('active', 1)->orderByRandom()->limit(10)->get();
编辑3:最后!从Laravel 5.2.33(changelog,PR#13642)开始,您可以使用本机方法inRandomOrder()
:
User::where('active', 1)->inRandomOrder()->limit(10)->get();
DB::table('users')->where('active', 1)->inRandomOrder()->limit(10)->get();
在Laravel 4和5中,order_by
替换为orderBy
因此,应为:
User::orderBy(DB::raw('RAND()'))->get();
您可以使用:
ModelName::inRandomOrder()->first();
对于Laravel 5.2> =
使用口才方法:
inRandomOrder()
inRandomOrder方法可用于对查询结果进行随机排序。例如,您可以使用此方法来获取随机用户:
$randomUser = DB::table('users')
->inRandomOrder()
->first();
来自文档:https : //laravel.com/docs/5.2/queries#ordering-grouping-limit-and-offset
您还可以流畅,雄辩地使用order_by方法,例如:
Posts::where_status(1)->order_by(DB::raw(''),DB::raw('RAND()'));
这有点奇怪,但是可以用。
编辑:正如@Alex所说,这种用法更清洁,也可以工作:
Posts::where_status(1)->order_by(DB::raw('RAND()'));
在您的模型上添加以下内容:
public function scopeRandomize($query, $limit = 3, $exclude = [])
{
$query = $query->whereRaw('RAND()<(SELECT ((?/COUNT(*))*10) FROM `products`)', [$limit])->orderByRaw('RAND()')->limit($limit);
if (!empty($exclude)) {
$query = $query->whereNotIn('id', $exclude);
}
return $query;
}
然后在路线/控制器处
$data = YourModel::randomize(8)->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();
$count
仅其中第一个ID的行将被检索到,那么与其他任何行相比,也更有可能被检索到。