Я хочу отфильтровать коллекцию товаров, чтобы показать только те товары, которые есть в наличии. Я думал, что это будет легко, учитывая, что есть атрибут is_salable, который равен 1 (true), если он есть в наличии, и 0 (false), если нет. Но независимо от того, что я делаю, это не работает. Кроме того, кажется, что он останавливает выполнение запроса до его завершения.
Вот пример кода:
$this->_productCollection = Mage::getModel('catalog/product')->getCollection();
$this->_productCollection->addAttributeToSelect('*');
$this->_productCollection->addAttributeToFilter('my_attribute', true);
//So far, so good...filtering on 'my_attribute' works!
Mage::Log("select: " . $this->_productCollection->getSelect());
//Successfully outputs the SQL query
$this->_productCollection->addFieldToFilter('is_salable', '1');
Mage::Log("select: " . $this->_productCollection->getSelect());
//does NOT output any query...it's like it died trying
Так что я делаю не так? Я пробовал 'addFieldToFilter', 'addAttributeToFilter' и другие другие запросы, такие как: addFieldToFilter('is_salable', array('eq' => true))
и т. Д. *
Кто-нибудь знает, как это сделать? Если «is_salable» не является ответом, все, что мне нужно сделать, это отфильтровать продукты, которых нет в наличии ... так что все, что нужно сделать, будет в порядке:)
Спасибо!