Друзья, это готовое задание, которое мне нужно!Я сделал это сам, а ты мне помог.Если кто-то заинтересованный может прочитать.
Я объясню вам, почему мне нужен именно этот метод.Я делаю интернет-магазин с часами, и теперь была задача сделать фильтры и атрибуты для фильтров.Таким образом, есть три таблицы
attribute_groups table

attribute_products table

attribute_values

Мне нужно отобразить виджет Laravel на моем .blade.php как
{{ Widget::run('filter', 'tpl' => 'widgets.filter', 'filter' => null,]) }}
Когда я создаю новый продукт в панели администратора.Я должен сохранить идентификатор продукта и attribute_id в attribute_products, но для одного продукта может быть как можно больше атрибутов.Итак, если я воспользуюсь этой опцией
$data = \DB::table('attribute_values')
->get()
->groupBy('attr_group_id')
->toArray();
Я получил результат:

Но!каждый новый массив начинается с индекса 0. Но мне нужен индекс, который означает его идентификатор.attr_group_id из таблицы attribute_value для сохранения в attribute_products.И после того, как я вижу только один метод для меня.
$data = \DB::table('attribute_values')->get();
$attrs = [];
foreach ($data as $key => $value) {
$attrs[$value->attr_group_id][$value->id] = $value->value;
}
return $attrs;
и результат, который я искал

теперь вы можетепосмотри какая разница и что было нужно.Индекс массива начинается с 1,2,3,4,5, и этот индекс = attr_group_id.К сожалению, я не смог изначально задать правильный вопрос.спасибо всем.