Magento - Toplama sırası belirlenemedi


11

Bu doğru bir şekilde sıralanmamış gibi görünüyor, yanlış yaptığım bir şey var mı? Öneriler?

$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');

Sıralanmamış gibi görünmeyen, birinciden farklı bir koleksiyon:

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

Yanıtlar:


42

EAV koleksiyonları niteliklerle çalışır, sıralama yöntemi de burada biraz farklıdır

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

EAV olmayan koleksiyonlar için aşağıdaki yöntemlerden birini kullanın

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

ikinci koleksiyon ne olacak?
easymoden00b

Bu düz tip bir koleksiyon, yani EAV ve nitelikler yok. Bunu nasıl sıralayacağınızla ilgili şu cevaba bir göz atın: stackoverflow.com/a/11354060
Sander Mangel

SetOrder'ı denedim ('related_sku', 'DESC'); ama sıralanmamış.
easymoden00b

Cevabımı düzenledim
Sander Mangel

2
@ easymoden00b bunu kullan$kitCollection->getSelect()->order('related_sku DESC');
Priyank


3

Burada diğer cevapları genişletmek için $kitCollection->getSelect()->order('column DESC')iyi çalışıyor, ancak birden fazla sütun ekleyemezsiniz. Örneğin $kitCollection->getSelect()->order('column DESC, column2 ASC')hata verir. Bunun nedeni, Magento'nun sütun adlarından kaçmak için yaptığı çalışmadır. Bu sorunu çözmek için aşağıdakini kullanabilirsiniz Zend_Db_Expr:

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

1

easymoden00b, setOrder()ürün üzerinde Eav yapısı nedeniyle çalışmıyor. @Sande addAttributeToSort()işlevini kullanmayı söylediğinden dolayı

  • Magento is join multiple tables for product collection.

  • Attribute alias name at collection

  • setOrder() functiono zaman çalışıyor order expression fieldName, SıralamaDüzeni olduğunu correct.

Magento'nun alan takma adı oluşturmanın nasıl olduğunu ve Mage_Eav_Model_Entity_Collection_Abstract sınıfındaki eav tablosu özniteliğini ilişkilendirdiğini görebilirsiniz.

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

İşte yapılandırılabilir bir ürünün özelliğindeki seçeneklerin sırasını sıralamak için benim çözümüm. Collection.php'yi kopyalayarak başlayın,

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

Sonra bu kodu bulabilirsiniz:

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

Ve bu kodla değiştirin:

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

Bu özellik seçenekleri açılır listesini alfabetik olarak sıralamanızı sağlar. Ayrıca array_reverse()veya benzer işlevleri kullanarak da sırayı tersine çevirebilirsiniz .

Önceden, özellik seçeneklerim ters alfabetik sıradaydı. Şimdi alfabetik sıradalar.

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.