1

我有以下 SQL 查询来检索产品:

$query = "SELECT *,m.m_name,m.m_website FROM belvg_countdown c 
INNER JOIN catalog_product_entity e ON e.entity_id=c.entity_id
LEFT JOIN manufacturers_products mp ON c.entity_id=mp.product_id
LEFT JOIN manufacturers m ON mp.manufacturers_id=m.manufacturers_id
WHERE DATE_FORMAT(expire_datetime_off , '%Y-%m-%d') > DATE_FORMAT(NOW() , '%Y-%m-%d')
AND DATE_FORMAT(expire_datetime_on , '%Y-%m-%d')!=DATE_FORMAT(NOW() , '%Y-%m-%d')
AND entity_type='product'";

现在,我还要添加一条语句,以仅加载名为“精选”类别的产品。你能帮我理解我应该比较/查询什么才能只获得“特色”产品吗?

谢谢。

4

2 回答 2

0

请参阅下面的 URL,它对您很有帮助

Magento ->addCategoryFilter - 按根类别过滤产品集合

或尝试一下

好的,我认为这行得通,没有进行太多测试,但似乎已经成功了。您需要首先获取您的商店根类别 ID,然后加入一些字段,以便您可以访问产品“category_id”,然后使用它进行过滤:

$_rootcatID = Mage::app()->getStore()->getRootCategoryId();

$_testproductCollection = Mage::getResourceModel('catalog/product_collection')
->joinField('category_id','catalog/category_product','category_id','product_id=entity_id',null,'left')
->addAttributeToFilter('category_id', array('in' => $_rootcatID))
->addAttributeToSelect('*');
$_testproductCollection->load();

foreach($_testproductCollection as $_testproduct){ 
    echo $this->htmlEscape($_testproduct->getName())."<br/>"; 
};
于 2012-09-06T18:12:48.423 回答
0

您不需要所有这些查询来从特定类别中获取有效产品。使用收藏。

$producs = Mage::getModel('catalog/category')->load(#categoryid or $_category->getId())
            ->getProductCollection()
            ->addAttributeToSelect('*')
            ->addAttributeToFilter('is_saleable', 1)
            ->joinField('is_in_stock', 'cataloginventory/stock_item', 'is_in_stock', 'product_id=entity_id', '{{table}}.stock_id=1', 'left');
于 2012-09-06T18:15:40.610 回答