0
$storeId = Mage::app()->getStore()->getId();
$products = Mage::getResourceModel('reports/product_collection')
->addOrderedQty()
->addAttributeToSelect(array('name', 'price', 'small_image', 'short_description', 'description'))
->addStoreFilter($storeId)
->setPageSize(4)
->setCurPage(1)
->setOrder('ordered_qty', 'desc')->load();

畅销书代码在 Magento 1.6.2 中不起作用。该集合甚至没有按商店过滤。

Zend_Debug::dump($storeId); 给了我string '2' (length=1),但我无法执行Zend_Debug::dump($products->getSelect());,因为它给了我一个错误There has been and error processing your request,它给了我以下查询:

SELECT SUM(order_items.qty_ordered) AS ordered_qty, order_items.name AS order_items_name, order_items.product_id AS entity_id, e.entity_type_id, e.attribute_set_id, e.type_id, e.sku, e.has_options, e.required_options, e.created_at, e.updated_at, e.name, e.price, e.small_image, e.short_description FROM tp_sales_flat_order_item AS order_items INNER JOIN tp_sales_flat_order AS order ON order.entity_id = order_items.order_id AND order.state <> 'cancelled' LEFT JOIN tp_catalog_product_entity AS e ON (e.type_id NOT IN ('grouped', 'configurable', 'bundle')) AND e.entity_id = order_items.product_id AND e.entity_type_id = 4 WHERE (parent_item_id IS NULL) GROUP BY order_items.product_id HAVING (SUM(order_items.qty_ordered) > 0) ORDER BY ordered_qty desc LIMIT 4

请帮我。

4

4 回答 4

1

尝试这个:

<?php 
    $products = Mage::getResourceModel('reports/product_collection')
               ->addAttributeToSelect('*')
               ->addOrderedQty($from, $to, true)
               ->addAttributeToSelect(array('name', 'price', 'small_image'))
               ->addCategoryFilter($category)
               ->setStoreId($storeId)
               ->addStoreFilter($storeId)
               ->setOrder('ordered_qty', 'desc');
?>
于 2015-01-31T09:32:57.123 回答
0

我在 magento 1.6.2 中也遇到过这类问题。我在过滤集合时发现属性过滤器存在一些问题。

我已经用addFieldToFilter替换了addAttributeToFilter并且它的工作。

试试这个可能对你有帮助

于 2012-04-21T11:42:40.810 回答
0

尝试这个:

$storeId = Mage::app()->getStore()->getId();
$products = Mage::getResourceModel('reports/product_collection')
->addOrdersCount()
->addAttributeToSelect(array('name', 'price', 'small_image', 'short_description', 'description'))
->addStoreFilter($storeId)
->setPageSize(4)
->setCurPage(1)
->setOrder('orders', 'desc')->load();

更改是 addOrdersCount() 方法和 ->setOrder() 方法。

于 2012-04-12T15:57:46.887 回答
0

尝试为您的收藏设置 storeid。添加 OrderedQty 后插入此行:

->setStoreId($storeId)
于 2013-06-11T11:07:49.383 回答