Перейти к содержанию

Рекомендуемые сообщения

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 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.