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

Сгенерировать артикул товара (model) через php запрос


Recommended Posts

Задача такая.

Сгенерировать код товара с префиксом названия категории в которой находится товар (первые 3 буквы).

 

Нашел подобный код, который генерирует код товара с префиксом названия производителя:

UPDATE `oc_product` p LEFT JOIN `oc_manufacturer` m ON(p.manufacturer_id = m.manufacturer_id) SET p.model = CONCAT(IF(LENGTH(m.name) > 0, UPPER(LEFT(m.name, 3)), 'STD'), '-', CONCAT(REPEAT('0', 6 - LENGTH(p.product_id)), p.product_id));

Пробую код:

UPDATE `oc_product` p LEFT JOIN `oc_category_description` cd ON(p.category_id = cd.category_id) SET p.model = CONCAT(IF(LENGTH(cd.name) > 0, UPPER(LEFT(cd.name, 3)), 'STD'), '-', CONCAT(REPEAT('0', 6 - LENGTH(p.product_id)), p.product_id))

 

Выдаёт ошибку

#1054 - Unknown column 'p.category_id' in 'on clause'

 

Подскажите, пожалуйста, что неверно?

 

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


1. В таблице oc_product нет category_id, он есть в таблице oc_product_to_category. Нужно добавить еще один LEFT JOIN

UPDATE `oc_product` p LEFT JOIN `oc_product_to_category` pc ON (p.product_id = pc.product_id) LEFT JOIN `oc_category_description` cd ON (pc.category_id = cd.category_id) SET p.model = CONCAT(IF(LENGTH(cd.name) > 0, UPPER(LEFT(cd.name, 3)), 'STD'), '-', CONCAT(REPEAT('0', 6 - LENGTH(p.product_id)), p.product_id))

Но проблема в том, что категорий у товара, в отличии от производителя, может быть несколько, поэтому нужно ставить условие на проверку главной. В общем лучше обратитесь к профессионалам за деньги.
P.S. Не забывайте делать бекап)

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


1 година назад, andrewborodiy сказав:

1. В таблице oc_product нет category_id, он есть в таблице oc_product_to_category. Нужно добавить еще один LEFT JOIN


UPDATE `oc_product` p LEFT JOIN `oc_product_to_category` pc ON (p.product_id = pc.product_id) LEFT JOIN `oc_category_description` cd ON (pc.category_id = cd.category_id) SET p.model = CONCAT(IF(LENGTH(cd.name) > 0, UPPER(LEFT(cd.name, 3)), 'STD'), '-', CONCAT(REPEAT('0', 6 - LENGTH(p.product_id)), p.product_id))

Но проблема в том, что категорий у товара, в отличии от производителя, может быть несколько, поэтому нужно ставить условие на проверку главной. В общем лучше обратитесь к профессионалам за деньги.
P.S. Не забывайте делать бекап)

Большое спасибо, работает!

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


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

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

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

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

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

Вхід

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

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

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

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

Important Information

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