Як змінити номер замовлення в Мадженто

Завдання: змінити номер замовлення при оформленні покупки в магазині на CMS Мадженто на більш короткий, наприклад, п’ятизначний і який містить букви.

 

Теорія:

Дані по замовленнях зберігаються в базі даних Мадженто в наступних таблицях:

eav_entity_store
eav_entity_type

 

В таблиці eav_entity_store є два стовпці (опції):

increment_prefix – автоматичний префікс приросту (перші значки, цифри) при формуванні номера замовлення

increment_last_id – останні зафіксовані замовлення (їх повні номера – id) в системі

 

 

В таблиці eav_entity_type налаштовується формат номера замовлень/доставок/інвойсів/повернень і т.д.

У цій таблиці нас цікавлять рядки order, invoice, shipment (їх значення в стовпці entity_type_id) і стовпець increment_pad_length.

Значення в стовпці increment_pad_length визначають кількість цифр в номері замовлення (без врахування префікса). За замовчуванням це 8.

 

 

Вихідні дані: нам потрібно, щоб наступний номер замовлення (доставки, інвойсу) починався з абревіатури нашої компанії (SW), стартував з 25 і містив всього п’ять цифр. Наприклад, повинен вийти номер SW25005.

 

Рішення:

1) для початку потрібно дізнатися використовувані в таблиці eav_entity_type значення entity_type_id (код операції). У нашому прикладі це:

  • 11 – ID для замовлень (order)
  • 19 – ID для доставки (shipment)

 

2) потрібно дізнатися використовувані в таблиці eav_entity_store значення для store_id (код магазину):

  • 1 – для дефолтної версії сайту
  • 8 – для української версії сайту

 

3) оновлюємо поле increment_prefix в таблиці eav_entity_store:

з 8 на SW25 для записів із store_id 8 в полях entity_type_id зі значеннями 11 (це для номера замовлення) і значенням 19 (це для номера доставки)

 

4) змінюємо поле increment_last_id в цій же таблиці на останній необхідний номер:

  • для номера замовлення з 800000512 на SW25005
  • і для номера доставки з 800000512 на SW25005

 

5) змінюємо для тих же ID операцій в таблиці eav_entity_type в полі increment_pad_length на 3 (довжина номера замовлення без префікса).

 

Фінальний результат: наступне замовлення в магазині буде мати номер SW25006.

 

Recent Posts

Уроки JavaScript — Короткі функції на заміну великому об’ємному коду

Досить часто у програмістів виникає спокуса написати якусь велику функцію, що повинна вирішувати певну задачу.…

4 дні ago

Навіщо та як прокидатися раніше

Дискусії навколо цієї теми вас, певно, вже втомили. Але я в даній статті постараюсь показати…

5 днів ago

Уроки JavaScript — Шпаргалка для розробників по роботі з консоллю у браузері

Консоль браузера (також відома як консоль JavaScript або веб-консоль), — це потужний інструмент для розробників,…

6 днів ago

Бернард Шоу

Ніколи не вказуйте на помилки, якщо не знаєте, як їх виправити Джордж Бернард Шоу  

1 тиждень ago

Вільям Джеймс

Коли необхідно зробити вибір, а ви його не робите, — це теж вибір Вільям Джеймс…

1 тиждень ago

Практичне застосування методики досягнення цілей SMART (5 прикладів)

Коли ви ставите перед собою цілі, дуже важливо бути максимально конкретним. Тут не допоможе проста…

1 тиждень ago