Я хотел бы отфильтровать коллекцию продуктов, чтобы показать только те товары, которые есть на складе. Я думал, что это будет легко, учитывая, что атрибут "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 like it died trying
Так что я делаю неправильно? Я пробовал "addFieldToFilter", "addAttributeToFilter" и другие другие запросы, такие как: addFieldToFilter('is_salable', array('eq' => true))
и т.д.
Кто-нибудь знает, как это сделать? Если "is_salable" не является ответом, все, что мне нужно сделать, это отфильтровать продукты, которые не находятся на складе... так что все, что работает, было бы хорошо:)
Спасибо!