在Eloquent中按自定义顺序对集合进行排序

Inv*_*tax 8 php arrays laravel eloquent

我有一个ID的数组如下:

$ids = [5,6,0,1]
Run Code Online (Sandbox Code Playgroud)

使用Eloquent我可以使用该->whereIn('id', $ids)功能搜索这些Id .正如预期的那样,将按Id的升序返回结果,有没有办法可以返回数组所在顺序的结果?或者,最简单的方法是按照$ids数组的顺序转换集合?

Ste*_*ake 12

如果您想要记录中的特定订单,则必须使用收集方法:

要按照您指定的特定顺序获取您的ID,您可以使用以下sortBy方法,其中collection是您的模型集合:

$ids = [ 5, 6, 0, 1];

$sorted = $collection->sortBy(function($model) use ($ids) {
    return array_search($model->getKey(), $ids);
});

// [ 5, 6, 0, 1] // (desired order)
Run Code Online (Sandbox Code Playgroud)

要随机化您的收藏,您可以使用该shuffle方法.

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

$shuffled = $collection->shuffle();

$shuffled->all();

// [3, 2, 5, 1, 4] // (generated randomly)
Run Code Online (Sandbox Code Playgroud)

Laravel文档shuffle和/或sortBy更具体的要求.

如果您没有真正考虑特定订单,则可以->inRandomOrder()在5.2及更高版本中使用,旧版本需要使用原始查询->orderBy(DB::raw('RAND()')).


Luk*_*rda 10

请参阅 Eloquent 中对MySQL order by field 的回答。可以对 SQL 查询中的数据进行排序。此处的其他答案建议您在以“错误”顺序获取数据后对数据进行排序。

您的代码应如下所示:

$ids = [5,6,0,1];

$collection = YourModel::whereIn('id', $ids)
    ->orderByRaw('FIELD (id, ' . implode(', ', $ids) . ') ASC')
    ->get();
Run Code Online (Sandbox Code Playgroud)

  • 注意:如果“$ids”是用户提供的数据且未正确转义,这可能会让您遭受 SQL 注入攻击。 (4认同)