在 Eloquent 中按自定义顺序对集合进行排序
我有一个ID数组,如下所示:
$ids = [5,6,0,1]
使用Eloquent,我能够使用该函数搜索这些Id。这将按预期按 Id 的升序返回结果,有没有办法按数组的顺序返回结果?或者,按数组顺序转换集合的最简单方法是什么?->whereIn('id', $ids)
$ids
我有一个ID数组,如下所示:
$ids = [5,6,0,1]
使用Eloquent,我能够使用该函数搜索这些Id。这将按预期按 Id 的升序返回结果,有没有办法按数组的顺序返回结果?或者,按数组顺序转换集合的最简单方法是什么?->whereIn('id', $ids)
$ids
如果要按特定顺序查看记录,则必须使用“收集方法”:
若要按照指定的非常具体的顺序获取 ID,可以按如下方式使用该方法,其中集合是模型的集合:sortBy
$ids = [ 5, 6, 0, 1];
$sorted = $collection->sortBy(function($model) use ($ids) {
return array_search($model->getKey(), $ids);
});
// [ 5, 6, 0, 1] // (desired order)
要随机化您的集合,您可以使用该方法。shuffle
$collection = collect([1, 2, 3, 4, 5]);
$shuffled = $collection->shuffle();
$shuffled->all();
// [3, 2, 5, 1, 4] // (generated randomly)
请参阅 Laravel 文档和/或了解更多具体要求。shuffle
sortBy
如果您没有真正考虑特定顺序,则可以在版本 5.2 及更高版本中使用,旧版本需要使用 的原始查询。->inRandomOrder()
->orderBy(DB::raw('RAND()'))
请参阅 Eloquent 中按字段对 MySQL 顺序的回答。可以对 SQL 查询中的数据进行排序。这里的其他答案是建议你在已经以“错误”的顺序获取数据后对数据进行排序。
您的代码应如下所示:
$ids = [5,6,0,1];
$collection = YourModel::whereIn('id', $ids)
->orderByRaw('FIELD (id, ' . implode(', ', $ids) . ') ASC')
->get();