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

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

Здравствуйте, подскажите, пожалуйста. Пытаюсь переделать модуль bestsellers таким образом, чтобы можно было убрать одну из категорий (слишком дешевый товар, и он естественно самый продаваемый), но в php по 5-ти бальной, максимум 2(

Изменено пользователем wikiparse

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


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

по быстрому

есть функция getBestSellerProducts в файле \catalog\model\catalog\product.php

в нем нужно добавить в запрос таблицу _product_to_category и написать какие категории тебе нужно выбросить.

 

по умному, нужно в админ части этого модуля сделать мультивыбор имеющихся категорий, в функции getBestSellerProducts в файле \catalog\model\catalog\product.php

в нем нужно добавить в запрос таблицу _product_to_category и прописать выбраные категории из админ части

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


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

по быстрому

есть функция getBestSellerProducts в файле \catalog\model\catalog\product.php

в нем нужно добавить в запрос таблицу _product_to_category и написать какие категории тебе нужно выбросить.

 

по умному, нужно в админ части этого модуля сделать мультивыбор имеющихся категорий, в функции getBestSellerProducts в файле \catalog\model\catalog\product.php

в нем нужно добавить в запрос таблицу _product_to_category и прописать выбраные категории из админ части

ну по умному - ни к чему, да и для меня сложновато))

запрос сейчас выглядит так:

$query = $this->db->query("SELECT op.product_id, COUNT(*) AS total FROM " . DB_PREFIX . "order_product op LEFT JOIN `" . DB_PREFIX . "order` o ON (op.order_id = o.order_id) LEFT JOIN `" . DB_PREFIX . "product` p ON (op.product_id = p.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE o.order_status_id > '0' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "' GROUP BY op.product_id ORDER BY total DESC LIMIT " . (int)$limit);

Подскажи, подалуйста, в каком месте и вставить _product_to_category, и как сделать множесственный выбор (т.е. нужно все, кроме одной).

Заранее спасибо) :-)

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


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

SELECT op.product_id, COUNT(*) AS total FROM os_order_product op LEFT JOIN `os_order` o ON (op.order_id = o.order_id) LEFT JOIN `os_product_to_category` ptc ON (ptc.product_id = op.product_id)  LEFT JOIN `os_product` p ON (op.product_id = p.product_id) LEFT JOIN os_product_to_store p2s ON (p.product_id = p2s.product_id) WHERE o.order_status_id > '0' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '0' and ptc.category_id not in (78) GROUP BY op.product_id ORDER BY total DESC LIMIT 6

 

ptc.category_id not in (XXXXX)

 

XXXXX = вписываем какие хотим категории убрать через запятую

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


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

От себя маленько добавлю, в старом ocstore (1.5.3) помоему, не работал запрос, пока не убрал везде os_, а в 1.5.6 os заменил на oc

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


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

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

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

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

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

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

Войти

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

Войти

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

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

×

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

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