Задать вопрос
@ragnar_ok

Как слить массивы объединив дубликаты пар ключ-значение?

Получаю результат выборки с использованием LEFT JOIN:

$array = [
    [
        'id' => 1,
        'order_id' => 1,
        'value' => 'foo',
    ],
    [
        'id' => 1,
        'order_id' => 1,
        'value' => 'bar',
    ],
    [
        'id' => 1,
        'order_id' => 1,
        'value' => 'baz',
    ]
];


Как слить массивы так, чтобы получить один массив с вложенностью? Универсально. Не по ключу value. Исходный массив $array может содержать и другие ключи с уникальными значениями.

$array = [
    [
        'id' => 1,
        'order_id' => 1,
        'value' => [
            'foo',
            'bar',
            'baz',
        ],
    ]
];


Может sql-запрос изменить?

SELECT table1.id, table2.order_id 
FROM table1
LEFT JOIN table2
ON table1.id = table2.order_id;
  • Вопрос задан
  • 120 просмотров
Подписаться 1 Простой Комментировать
Помогут разобраться в теме Все курсы
  • Skillfactory
    Профессия Fullstack веб-разработчик на JavaScript и PHP
    20 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Нетология
    Веб-разработчик с нуля: профессия с выбором специализации
    14 месяцев
    Далее
Решения вопроса 1
trapwalker
@trapwalker
Программист, энтузиаст
Делайте group by по нужным полям, а остальные агрегируйте с помощью group_concat.
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
FoodSoul Калининград
от 180 000 до 250 000 ₽
IT-Spirit Москва
от 230 000 до 320 000 ₽
от 200 000 до 290 000 ₽