Объединить строку с одинаковым product_id, но разным style_id в каждой строке - PullRequest
0 голосов
/ 29 мая 2018

У меня проблема с достижением желаемого результата.У меня есть таблица, которая содержит product_id и style_id.Каждый продукт содержит 1 или много разных стилей.Столбец style_id не может быть одинаковой комбинацией с любыми строками.

Примечание Я хочу добиться этого результата с помощью SQL запроса или с использованием PHP кода.

product_style

id      product_id     style_id
1           1             1
2           1             2
3           1             3
4           1             4
5           2             1

И я хочу достичь этого результата с помощью SQL-запроса или с помощью PHP-кода .

  Array[12][
    {
      "id": 1,
      "name": "Product sample",
      "description": "Sample",
      "price": "11.00",
      "level": "school",
      "style_name":{[
           "Style 1",
           "Style 2",
           "Style 3",
           "Style 4"
          ]
      }
      "style_id": {[
          1,
          2,
          3,
          4,
        ]
      },
      "rank_id": 232
    }
    {
      "id": 2,
      "name": "Sample 2",
      "description": "Sample 2",
      "price": "10.00",
      "level": "school",
      "style_name": "Karate",
      "style_id": 1,
      "rank_id": 232
    }
  ]

это мой текущий код.

$grading_products= \DB::table('products as p')
                  ->leftjoin('product_style as ps', 'p.id', '=', 'ps.product_id')
                  ->join('style_users as su', 'ps.style_id', '=', 'su.style_id')
                  ->join('styles as s', 'ps.style_id', '=', 's.id')
                  ->whereRaw('su.user_id = ' .$id. ' AND p.product_type_id = 1 AND p.service_sub_type_id = 2')
                  ->select('p.id', 'p.name', 'p.description', 'p.price', 'p.level', 'ps.product_id', 's.name as style_name', 'ps.style_id as ps_style', 'su.style_id', 'su.rank_id')
                  ->get();

и это мой текущий выход

Array[12][
  {
    "id": 1,
    "name": "Product Sample",
    "description": "Sample",
    "price": "11.00",
    "level": "school",
    "style_name": "style 1",
    "style_id": 1,
    "rank_id": 232
  },
  {
    "id": 1,
    "name": "Product Sample",
    "description": "Sample",
    "price": "11.00",
    "level": "school",
    "style_name": "style 2",
    "style_id": 2,
    "rank_id": 232
  }
  {
      "id": 2,
      "name": "Sample 2",
      "description": "Sample 2",
      "price": "10.00",
      "level": "school",
      "style_name": "Karate",
      "style_id": 1,
      "rank_id": 232
  },
]

Примечание Я хочу достичь этого результата с помощью SQL запроса или с использованием PHP кода.

1 Ответ

0 голосов
/ 29 мая 2018

Используя ваш текущий выход в качестве отправной точки, вот грязное решение:

$new_output = [];

$keyed = [];

foreach ($current_output as $row) {
    $keyed[$row['id']]['style_name'][] = $row['style_name'];

    $keyed[$row['id']]['style_id'][] = $row['style_id'];

    $keyed[$row['id']]['row'] = $row;
}

foreach ($keyed as $id => $data) {
    $row = $data['row'];

    $temp_output = [
        'id' => $id,
        'name' => $row['name'],
        'description' => $row['description'],
        'price' => $row['price'],
        'level' => $row['level'],
    ];

    if (count($keyed[$row['id']]['style_name']) > 1) {
        $temp_output['style_name'] = $data['style_name'];
    } else {
        $temp_output['style_name'] = $data['style_name'][0];
    }

    if (count($keyed[$row['id']]['style_id']) > 1) {
        $temp_output['style_id'] = $data['style_id'];
    } else {
        $temp_output['style_id'] = $data['style_id'][0];
    }

    $temp_output['rank_id'] = $row['rank_id'];

    $new_output[] = $temp_output;
}

(не проверено)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...