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

Как исправить ошибку при сохранении изменений товара?


Recommended Posts

Периодически, при сохранении товара, возникает такая ошибка

Fatal error: Uncaught Exception: Error: Duplicate entry '244' for key 'PRIMARY'<br />Error No: 1062<br />INSERT INTO oc_product_option SET product_option_id = '244', product_id = '63', option_id = '14', required = '1'

Насколько это опасно и возможно ли как-то исправить?

Смотрю модифицированный файл - все в норме - сначала идет удаление, а потом добавление в данную таблицу

$this->db->query("DELETE FROM " . DB_PREFIX . "product_option WHERE product_id = '" . (int)$product_id . "'");
$this->db->query("DELETE FROM " . DB_PREFIX . "product_option_value WHERE product_id = '" . (int)$product_id . "'");

if (isset($data['product_option'])) {
    foreach ($data['product_option'] as $product_option) {
        if ($product_option['type'] == 'select' || $product_option['type'] == 'radio' || $product_option['type'] == 'checkbox' || $product_option['type'] == 'image') {
            if (isset($product_option['product_option_value'])) {
                $this->db->query("INSERT INTO " . DB_PREFIX . "product_option SET product_option_id = '" . (int)$product_option['product_option_id'] . "', product_id = '" . (int)$product_id . "', option_id = '" . (int)$product_option['option_id'] . "', required = '" . (int)$product_option['required'] . "'");

                $product_option_id = $this->db->getLastId();

                foreach ($product_option['product_option_value'] as $product_option_value) {

            $this->db->query("INSERT INTO " . DB_PREFIX . "product_option_value SET product_option_value_id = '" . (int)$product_option_value['product_option_value_id'] . "', product_option_id = '" . (int)$product_option_id . "', product_id = '" . (int)$product_id . "', option_id = '" . (int)$product_option['option_id'] . "', option_value_id = '" . (int)$product_option_value['option_value_id'] . "', quantity = '" . (int)$product_option_value['quantity'] . "', option_default = '" . (int)$product_option_value['option_default'] . "', subtract = '" . (int)$product_option_value['subtract'] . "', price = '" . (float)$product_option_value['price'] . "', price_prefix = '" . $this->db->escape($product_option_value['price_prefix']) . "', points = '" . (int)$product_option_value['points'] . "', points_prefix = '" . $this->db->escape($product_option_value['points_prefix']) . "', weight = '" . (float)$product_option_value['weight'] . "', weight_prefix = '" . $this->db->escape($product_option_value['weight_prefix']) . "'");

                }
            }
        } else {
            $this->db->query("INSERT INTO " . DB_PREFIX . "product_option SET product_option_id = '" . (int)$product_option['product_option_id'] . "', product_id = '" . (int)$product_id . "', option_id = '" . (int)$product_option['option_id'] . "', value = '" . $this->db->escape($product_option['value']) . "', required = '" . (int)$product_option['required'] . "'");
        }
    }
}

 

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


Дополнение. Добавлял sleep после удаления опций товара из БД и да, они все же удаляются. Но все равно ругается, хотя в первичном ключе такого значения уже нет... Что такое может быть и как поправить?

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


1 минуту назад, nikifalex сказал:

тут ведь какая-то дичь??

Это стандартный код OC. Я тут ничего не менял. И проблема не только в этой таблице. Просто в опциях первой отказывает.

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


  • 1 month later...
В 13.07.2019 в 14:44, Muvka сказал:

Всем спасибо. Проблема была в том, что форма 2 раза отправлялась.

А вот у меня та же ошибка + копирование товаров и создание групп пользователей происходит дважды. 
Как побороли?

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


  • 2 weeks later...
В 30.08.2019 в 14:11, Vladimir7 сказал:

А вот у меня та же ошибка + копирование товаров и создание групп пользователей происходит дважды. 
Как побороли?

Извиняюсь. Не видел уведомление. Я удалил вот этот код

//Form Submit for IE Browser
$('button[type=\'submit\']').on('click', function() {
    $("form[id*='form-']").submit();
});

в admin/view/javascript/common.js

Из-за этой гадости форма 2 раза отправляется на сохранение.

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


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

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

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

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

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

Вхід

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

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

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

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

Important Information

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