У меня есть запрос ниже, который возвращает OrderID, order_item_id, _product_id, Quantity.Объединить запросы в один
SELECT `wp_woocommerce_order_items`.`order_id` AS 'OrderID',
`wp_woocommerce_order_items`.`order_item_id`,
MAX(CASE WHEN `wp_woocommerce_order_itemmeta`.`meta_key` = '_product_id' THEN `wp_woocommerce_order_itemmeta`.`meta_value` ELSE NULL END) AS '_product_id',
MAX(CASE WHEN `wp_woocommerce_order_itemmeta`.`meta_key` = '_qty' THEN `wp_woocommerce_order_itemmeta`.`meta_value` ELSE NULL END) AS 'Quantity'
FROM `wp_woocommerce_order_items`, `wp_woocommerce_order_itemmeta`
WHERE `wp_woocommerce_order_items`.`order_id` = 50
AND `wp_woocommerce_order_items`.`order_item_id` = `wp_woocommerce_order_itemmeta`.`order_item_id`
AND `wp_woocommerce_order_items`.`order_item_type` = 'line_item'
AND (`wp_woocommerce_order_itemmeta`.`meta_key` = '_qty'
OR `wp_woocommerce_order_itemmeta`.`meta_key` = '_product_id')
GROUP BY `wp_woocommerce_order_items`.`order_item_id`
Возвращает:
+---------+---------------+-------------+----------+
| OrderID | order_item_id | _product_id | Quantity |
+---------+---------------+-------------+----------+
| 50 | 11 | 27 | 3 |
| 50 | 18 | 42 | 1 |
+---------+---------------+-------------+----------+
Я тогда цикл по каждой строке приведенного выше результата в PHP использовать _product_id в запросе ниже, чтобы соответствовать wp_postmeta
. post_id
.
SELECT `post_id`,
MAX(CASE WHEN `wp_postmeta`.`meta_key` = '_sku' THEN `wp_postmeta`.`meta_value` ELSE NULL END) AS 'PartNumber',
MAX(CASE WHEN `wp_postmeta`.`meta_key` = '_price' THEN `wp_postmeta`.`meta_value` ELSE NULL END) AS 'UnitPrice'
FROM `wp_postmeta`
WHERE `wp_postmeta`.`post_id` = $PRODUCT_ID
AND (`wp_postmeta`.`meta_key` = '_sku'
OR `wp_postmeta`.`meta_key` = '_price')
Возвращает:
+---------+------------+-----------+
| post_id | PartNumber | UnitPrice |
+---------+------------+-----------+
| 27 | MOO123 | 50 |
+---------+------------+-----------+
+---------+------------+-----------+
| post_id | PartNumber | UnitPrice |
+---------+------------+-----------+
| 42 | MOO345 | 145 |
+---------+------------+-----------+
Есть ли способ объединить два, так что это добавляет PartNumber
и UnitPrice
на первый результат запроса и возвращает данные, как показано ниже?
+---------+---------------+-------------+----------+------------+-----------+
| OrderID | order_item_id | _product_id | Quantity | PartNumber | UnitPrice |
+---------+---------------+-------------+----------+------------+-----------+
| 50 | 11 | 27 | 3 | MOO123 | 50 |
| 50 | 18 | 42 | 1 | MOO345 | 145 |
+---------+---------------+-------------+----------+------------+-----------+
Таблица данных здесь: http://pastebin.com/3EN5P4fD
Благодарность
Я получаю следующую ошибку, любые идеи? # 1054 - Неизвестный столбец 'wp_postmeta.meta_key' в 'where clause'. Спасибо – arbme
См. Мое редактирование в запросе. Я изменил 'wp_postmeta' на' p'. – GregD
Новая ошибка: # 1111 - Недопустимое использование групповой функции. Еще раз спасибо. – arbme