Magento - Impossibile impostare l'ordine di raccolta


11

Questo non sembra essere stato ordinato correttamente, qualcosa che sto facendo di sbagliato? Suggerimenti?

$componentQuantityCollection = Mage::getModel('catalog/product')->getCollection();
$componentQuantityCollection->joinField('qty',
    'cataloginventory/stock_item',
    'qty',
    'product_id=entity_id',
    '{{table}}.stock_id=1',
    'left');
$componentQuantityCollection->addAttributeToFilter('sku', array('in' => $componentSkus))->setOrder('sku','ASC');

Un'altra collezione che non sembra essere ordinata, che è diversa dalla prima:

$kitCollection = Mage::getModel('kitinventory/kitinventory')->getCollection()->addFieldToFilter('kit_sku', $sku)->setOrder('related_sku', 'DESC');

Risposte:


42

Le raccolte EAV funzionano con gli attributi, anche qui il metodo di ordinamento è leggermente diverso

$componentQuantityCollection->addAttributeToSort('sku', 'ASC');

Per le raccolte non EAV utilizzare uno dei seguenti metodi

$kitCollection->getSelect()->order('related_sku DESC');
$kitCollection->setOrder('related_sku', 'DESC');

che dire della seconda collezione?
easymoden00b,

È una raccolta di tipi piatti, quindi nessun EAV e attributi. Dai un'occhiata a questa risposta su come ordinare ciò: stackoverflow.com/a/11354060
Sander Mangel

Ho provato setOrder ('related_sku', 'DESC'); ma non è ordinato.
easymoden00b,

Ho modificato la mia risposta
Sander Mangel

2
@ easymoden00b usa questo$kitCollection->getSelect()->order('related_sku DESC');
Priyank il


3

Per espandere qui le altre risposte, $kitCollection->getSelect()->order('column DESC')funziona bene, ma non puoi aggiungere più di una colonna. Ad esempio, $kitCollection->getSelect()->order('column DESC, column2 ASC')sarà errore. Ciò è dovuto al lavoro svolto da Magento per sfuggire ai nomi delle colonne. Per aggirare questo, puoi usare un Zend_Db_Exprlike così:

$kitCollection->getSelect()->order(new Zend_Db_Expr('related_sku DESC, column2 ASC'));

1

easymoden00b, setOrder()non funziona a causa della struttura Eav sul prodotto. Come dice @Sande per usare la addAttributeToSort()funzione, a causa di

  • Magento is join multiple tables for product collection.

  • Attribute alias name at collection

  • setOrder() functionfunziona quando order expression Fieldname, SortOrder è correct.

Puoi vedere come Magento è creare un alias di campo e si riferisce all'attributo eav table alla classe Mage_Eav_Model_Entity_Collection_Abstract

public function addAttributeToSort($attribute, $dir = self::SORT_ORDER_ASC)
{
    if (isset($this->_joinFields[$attribute])) {
        $this->getSelect()->order($this->_getAttributeFieldName($attribute).' '.$dir);
        return $this;
    }
    if (isset($this->_staticFields[$attribute])) {
        $this->getSelect()->order("e.{$attribute} {$dir}");
        return $this;
    }
    if (isset($this->_joinAttributes[$attribute])) {
        $attrInstance = $this->_joinAttributes[$attribute]['attribute'];
        $entityField = $this->_getAttributeTableAlias($attribute) . '.' . $attrInstance->getAttributeCode();
    } else {
        $attrInstance = $this->getEntity()->getAttribute($attribute);
        $entityField = 'e.' . $attribute;
    }

    if ($attrInstance) {
        if ($attrInstance->getBackend()->isStatic()) {
            $orderExpr = $entityField;
        } else {
            $this->_addAttributeJoin($attribute, 'left');
            if (isset($this->_joinAttributes[$attribute])||isset($this->_joinFields[$attribute])) {
                $orderExpr = $attribute;
            } else {
                $orderExpr = $this->_getAttributeTableAlias($attribute).'.value';
            }
        }

        if (in_array($attrInstance->getFrontendClass(), $this->_castToIntMap)) {
            $orderExpr = Mage::getResourceHelper('eav')->getCastToIntExpression(
                $this->_prepareOrderExpression($orderExpr)
            );
        }

        $orderExpr .= ' ' . $dir;
        $this->getSelect()->order($orderExpr);
    }
    return $this;
}

1

Ecco la mia soluzione per ordinare l'ordine delle opzioni nell'attributo di un prodotto configurabile. Inizia copiando Collection.php,

app/code/core/Mage/Catalog/Model/Resource/Product/Type/Configurable/Attribute/Collection.phpa app/code/local/Mage/Catalog/Model/Resource/Product/Type/Configurable/Attribute/Collection.php.

Quindi puoi trovare questo codice:

foreach ($this->getProduct()->getTypeInstance(true)->getUsedProducts(array($productAttribute->getAttributeCode()), $this->getProduct()) as $associatedProduct) {

E sostituiscilo con questo codice:

$assProds = $this->getProduct()->getTypeInstance(true)->getUsedProducts(array($productAttribute->getAttributeCode()), $this->getProduct());
sort($assProds);
foreach ($assProds as $associatedProduct) {

Ciò ti consentirà di ordinare in ordine alfabetico l'elenco a discesa delle opzioni di attributo. È inoltre possibile invertire l'ordine utilizzando array_reverse()o funzioni simili.

In precedenza, le mie opzioni di attributo erano in ordine alfabetico inverso. Ora sono in ordine alfabetico.

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.