0

我有一个这样的类别结构:

Root Cat
  Sub Cat 1
  Sub Cat 2
  Sub Cat 3

和产品系列:

$productCollection = Mage::getResourceModel('catalog/product_collection');

现在我想按类别对集合中的产品进行排序。Sub Cat 1 产品应该首先出现,然后是 Sub Cat 2 产品,最后是 Sub Cat 3 产品。如果我更改类别的顺序,集合中产品的顺序也应该改变。我怎样才能做到这一点?一个简单的$productCollection->addAttributeToSort('category');还是$productCollection->setOrder('category')不行。

提前致谢!

4

1 回答 1

1

我认为您无法通过简单地修改集合来实现您想要的所有功能。category不是属性。category_ids是,但是当我尝试对其进行排序时,它没有任何效果。

我会获取类别(按照您想要的顺序),然​​后使用该addCategoryFilter()功能从这些类别中获取产品。

例子:

$categories = Mage::getModel('catalog/category')->getCollection();
foreach ($categories as $category) {
    echo $category->getId() . ':' . PHP_EOL;
    $products = Mage::getModel('catalog/product')->getCollection()
        ->addCategoryFilter($category);
    foreach ($products as $product) {
        // Do something
        echo '  ' . $product->getSku() . PHP_EOL;
    }
}
于 2012-04-08T15:23:48.877 回答