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

Копирование товара и Рекомендуемые [решено]

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

Может быть кто-то уже сталкивался с такой проблемой? Мне она уже жить спокойно не дает...

При копировании товара в Админке, этот вновь созданный копированием товар почему-то автоматически попадает в Рекомендуемые ко всем остальным товарам в магазине. Нет, даже не ко всем, а по какому-то странному и не понятному мне алгоритму... А это не правильно...

Работаю на ocStore 0.1.1.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Интересная бага. Изменения вносились?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Интересная бага. Изменения вносились?

Изменения не вносились, в чём ошибка разобрался. Проблема вот в чём:

Файл /admin/catalog/model/product.php, функция addProduct, строки:

$this->db->query("INSERT INTO " . DB_PREFIX . "product_related SET product_id = '" . (int)$product_id . "', related_id = '" . (int)$related_id . "'");
$this->db->query("INSERT INTO " . DB_PREFIX . "product_related SET product_id = '" . (int)$related_id . "', related_id = '" . (int)$product_id . "'");
первая строка создаёт в базе рекомендуемых пару: Товар - Рекомендуемый, вторая создаёт обратную пару Рекомендуемый - Товар. Т.е. авторы скрипта полагают, что если я рекомендую к товару А, товар Б, то и обратная рекомендация тоже истина. Но мне кажется, это не всегда так... Это во-первых... А во-вторых, это и приводит к описанной выше ошибке - созданию множества перекрестных ссылок которых никто не создавал.

Аналогичный фрагмент кода есть и в функции editProduct:

$this->db->query("INSERT INTO " . DB_PREFIX . "product_related SET product_id = '" . (int)$product_id . "', related_id = '" . (int)$related_id . "'");
$this->db->query("DELETE FROM " . DB_PREFIX . "product_related WHERE product_id = '" . (int)$related_id . "' AND related_id = '" . (int)$product_id . "'");
$this->db->query("INSERT INTO " . DB_PREFIX . "product_related SET product_id = '" . (int)$related_id . "', related_id = '" . (int)$product_id . "'");

В общем, я у себя эти фрагменты кода, которые работают с обратной парой (Рекомендуемый - Товар) отключил. Посмотрю что получится.

ПС: а что, кроме меня никто не пользуется функцией копирования товаров?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Скорее всего, в тихоря себе поправили и молчат :(

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

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

×

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

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