Laravel - Eloquent或Fluent随机排

时间:2012-12-17 15:59:25

标签: php fluent laravel eloquent

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

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

有什么想法吗?

15 个答案:

答案 0 :(得分:458)

Laravel> = 5.2:

User::inRandomOrder()->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随机行上的 this article 。 Laravel 5.2支持这一点,对于旧版本,使用RAW Queries时没有更好的解决方案。

编辑1:正如Double Gras所述,自this更改以来,orderBy()不允许任何其他内容,而是ASC或DESC。我相应地更新了我的答案。

编辑2: Laravel 5.2最终为此实现了a wrapper function。它被称为 inRandomOrder()

答案 1 :(得分:41)

这很好用,

$model=Model::all()->random(1);

您还可以在随机函数中更改参数以获取多条记录。

注意:如果您有大量数据,则不建议使用,因为这将首先获取所有行,然后返回随机值。

答案 2 :(得分:29)

tl;博士:现在已经在Laravel中实施了,请参阅"编辑3"下方。


可悲的是,截至今天,->orderBy(DB::raw('RAND()'))建议的解决方案有一些注意事项:

  • 它不是与数据库无关的。例如SQLite和PostgreSQL使用RANDOM()
  • 更糟糕的是,此解决方案不再适用this change

    $direction = strtolower($direction) == 'asc' ? 'asc' : 'desc';


修改:现在您可以使用orderByRaw()方法:->orderByRaw('RAND()')。然而,这仍然不是DB不可知的。

FWIW,CodeIgniter实现了一个特殊的RANDOM排序方向,在构建查询时将其替换为正确的语法。它似乎也很容易实现。看起来我们有改进Laravel的候选人:)

更新:这是关于GitHub的issue以及我的待审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(changelogPR #13642)以来,您可以使用本机方法inRandomOrder()

User::where('active', 1)->inRandomOrder()->limit(10)->get();

DB::table('users')->where('active', 1)->inRandomOrder()->limit(10)->get();

答案 3 :(得分:17)

Laravel 4和5 中,order_byorderBy替换

所以,它应该是:

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

答案 4 :(得分:8)

您还可以使用具有流利和雄辩的order_by方法,如:

Posts::where_status(1)->order_by(DB::raw(''),DB::raw('RAND()')); 

这有点奇怪,但有效。

编辑:正如@Alex所说,这种用法更清晰,也有效:

Posts::where_status(1)->order_by(DB::raw('RAND()'));

答案 5 :(得分:8)

对于Laravel 5.2> =

使用Eloquent方法:

self.webViewA.scrollView.delegate = self;

- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    UIWebView *webViewB = // ...
    [webViewB setContentOffset:scrollView.contentOffset animated:YES];
}

inRandomOrder方法可用于随机对查询结果进行排序。例如,您可以使用此方法来获取随机用户:

inRandomOrder()

来自docs:https://laravel.com/docs/5.2/queries#ordering-grouping-limit-and-offset

答案 6 :(得分:2)

还有whereRaw('RAND()')也会这样做,然后您可以链接->get()->first(),甚至疯狂添加->paginate(int)

答案 7 :(得分:2)

在您的模型中添加:

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

答案 8 :(得分:1)

您可以轻松使用此命令:

//问题:模型的名称
//从数据库中取10行在随机播放记录中......

$questions = Question::orderByRaw('RAND()')->take(10)->get();

答案 9 :(得分:0)

我有数千条记录的表格,所以我需要快速的东西。这是伪随机行的代码:

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

答案 10 :(得分:0)

使用Laravel函数

ModelName::inRandomOrder()->first();

答案 11 :(得分:0)

我希望先指定还是失败:

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

答案 12 :(得分:0)

Laravel具有内置的方法,可以随机排列结果的顺序。

以下是文档中的引言:

shuffle()

随机播放方法随机随机播放集合中的项目:

$collection = collect([1, 2, 3, 4, 5]);

$shuffled = $collection->shuffle();

$shuffled->all();

// [3, 2, 5, 1, 4] - (generated randomly)

您可以看到documentation here

答案 13 :(得分:0)

在Laravel 7.x及更高版本中,您可以执行以下操作:

datasource

答案 14 :(得分:0)

以下是我在我的一个项目中获得随机结果的方法:

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

10 - 要提取的随机记录数。