Как указать пользовательский порядок сортировки для коллекции товаров?

12

Я пытаюсь создать коллекцию продуктов на основе массива идентификаторов продуктов, а также сортировать коллекцию на основе массива идентификаторов.

$productIds = array(318,310,311);
$collection = Mage::getModel('catalog/product')
        ->getCollection()
        ->setOrder('entity_id', 'asc') // This will not do the job
        ->addAttributeToSelect('*')
        ->addAttributeToFilter('status', 1)
        ->addAttributeToFilter('entity_id', array(
    'in' => $productIds,
        ));

Я хочу отсортировать собранные, как они появляются в $productIdsмассиве, 318, 310, 311но выше код будет возвращать сортировку коллекции, как 310,311, 312.

Возможно ли это без использования простого запроса MySQL, как указано ниже?

SELECT *
FROM catalog_product_entity
WHERE entity_id IN (318,
                    310,
                    311)
ORDER BY FIELD(entity_id, 318, 310, 311);
Тахир Ясин
источник

Ответы:

18

К сожалению, Magento проверит параметры заказа в Varien_Data_Collection_Db _setOrderфункции. Но вы можете получить выбор коллекции и добавить новое выражение для построения порядка, как вам нравится.

/* @var $collection Mage_Catalog_Model_Resource_Product_Collection */
$collection = Mage::getModel('catalog/product')
    ->getCollection()
    ->addAttributeToSelect('*')
    ->addAttributeToFilter('status', 1)
    ->addAttributeToFilter('entity_id', array(
            'in' => $productIds,
        ));

$collection->getSelect()->order(new Zend_Db_Expr('FIELD(e.entity_id, ' . implode(',', $productIds).')'));

foreach($collection as $product) {
    var_dump($product->getId());
}

Здесь вы должны увидеть, что идентификаторы продуктов расположены в порядке массива.

Дэвид Мэннерс
источник
Оно работает! Спасибо. Можем ли мы объединить сортировку по SKU выше?
Тахир Ясин
Вы можете добавить несколько полей в этот порядок по синтаксисуFIELD(x, 1, 2, 3), FIELD(y, 3, 2, 1)
Дэвид Мэннерс