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

getProductSpecials - выбрать товары с количеством > 0


Recommended Posts

Здравствуйте!

Помогите, пожалуйста. Как в методе getProductSpecials модуля specials выбрать товары в наличии?

А то, если продукт на складе закончился, он все-равно отображается в модуле на главной.

 

 

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


SELECT *
  FROM product_special ps
  WHERE ps.product_id = '30'
    AND (SELECT quantity
                FROM product p
                WHERE p.product_id = ps.product_id
                  AND quantity >0
             ) >1
ORDER BY ps.priority, ps.price

Надеюсь, остальное сделаете

 

 

Но может понадобится и такое

SELECT *, (SELECT  	quantity FROM " .   DB_PREFIX . "product p WHERE p.product_id = '" . (int)$product_id ." AND quantity > 0) as quantity
	FROM " . DB_PREFIX . "product_special  ps
	WHERE ps.product_id = '" . (int)$product_id . "' ORDER BY ps.priority, ps.price");


Внимание! Если у вас мултимагазин - работать не будет.

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

Можно и так, но на ночь запрос с подзапросом отработал быстрее. Хотя по идее должно быть наоборот

SELECT ps.*
    FROM product_special  ps
INNER JOIN product p ON p.product_id = ps.product_id
    WHERE ps.product_id = '30'
            AND p.quantity > 0
ORDER BY ps.priority, ps.price
Надіслати
Поділитися на інших сайтах

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

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

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

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

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

Вхід

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

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

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

Important Information

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