Перейти до вмісту
Пошук в
  • Детальніше...
Шукати результати, які ...
Шукати результати в ...

Поиск в истории заказов по артикулу


Recommended Posts

Opencar 2.3 Пытаюсь сделать в исории заказа фильтр поиска по артикулу Не получаеться написать запрос

 

Нужно получить Артикулы (sku) из таблички oc_order_product и записать  в табличку oc_order
при условии что id таблички oc_order_product = id таблички oc_order_product


Табличка oc_order

-----------------------------
|order_id|firstname|lastname|
|1            |Igor         |Volk      |     
|2            |Vova       |Alex      |
|3            |Sasha     |ivanov  |
-------------------------------------- 

Табличка oc_order_product

----------------------------------------------------
|order_product_id|order_id  |product_id|
|1                         |1             |42             |     
|2                         |2             |43             |
|3                         |3             |44             |
----------------------------------------------------

Табличка oc_order_product
---------------------------
|product_id   |sku      |
|42                |1fdf     |          
|43                |2123   |         
|44                |34543 |   
----------------------------

Результат 

-------------------------------------------------
|order_id|firstname|lastname|sku      |
|1           |Igor         |Volk        |1fdf     |          
|2           |Vova       |Alex        |2123   |
|3           |Sasha     |ivanov    |34543  |
--------------------------------------------------

 

 

Вот вариант мого запроса 

 

SELECT o.order_id, o.firstname, o.lastname, (SELECT p.sku FROM oc_order_product op LEFT JOIN oc_product p ON op.product_id = p.product_id) AS sku, (SELECT os.name FROM oc_order_status os WHERE os.order_status_id = o.order_status_id AND os.language_id = '1') AS status, o.shipping_code, o.total, o.currency_code, o.currency_value, o.date_added, o.date_modified FROM `oc_order` o LIMIT 1, 20

 

Но выдает ошибку  Subquery returns more than 1 row

Змінено користувачем powersvolk2
Надіслати
Поділитися на інших сайтах


А зачем вам что-то записывать в oc_order?

Вы можете просто по product_id прицепить oc_product к oc_order_product и оттуда взять sku

Надіслати
Поділитися на інших сайтах

Если кому интересно сделал вот так 

SELECT o.order_id, o.firstname, o.lastname, p.sku as sku, (SELECT os.name FROM oc_order_status os WHERE os.order_status_id = o.order_status_id AND os.language_id = '1') AS status, o.shipping_code, o.total, o.currency_code, o.currency_value, o.date_added, o.date_modified FROM `oc_order` o LEFT JOIN oc_product p ON (product_id = p.product_id) LIMIT 1, 100

Надіслати
Поділитися на інших сайтах


Створіть аккаунт або увійдіть для коментування

Ви повинні бути користувачем, щоб залишити коментар

Створити обліковий запис

Зареєструйтеся для отримання облікового запису. Це просто!

Зареєструвати аккаунт

Вхід

Уже зареєстровані? Увійдіть тут.

Вхід зараз
  • Зараз на сторінці   0 користувачів

    • Ні користувачів, які переглядиють цю сторінку

×
×
  • Створити...

Important Information

На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність.