Завдання: змінити номер замовлення при оформленні покупки в магазині на 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 (код операції). У нашому прикладі це:
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 в цій же таблиці на останній необхідний номер:
5) змінюємо для тих же ID операцій в таблиці eav_entity_type в полі increment_pad_length на 3 (довжина номера замовлення без префікса).
Фінальний результат: наступне замовлення в магазині буде мати номер SW25006.
WordPress роками був неперевершеним "монолітом": він відповідав і за зручну адмін-панель, і за збереження даних,…
У світі веб-серверів часто говорять про протистояння Nginx vs Apache. Але що, якби я сказав…
Коли я починав свій шлях у веб-розробці, питання "який веб-сервер використовувати?" практично не стояло. Відповідь…
Коли мова заходить про веб-сервери, два імені завжди на слуху: Apache та Nginx. Apache —…
У світі веб-розробки ми постійно стикаємося з проблемою: "А в мене на комп'ютері все працює!".…
На зорі моєї кар'єри веб-розробника все було відносно просто: встановив локальний сервер (пам'ятаєте Denwer?), поклав…