2

コレクションを数量でフィルタリングしようとしまし $_productCollection->addAttributeToFilter('qty', array('gt' => 30)); たが、うまくいきません。

製品コレクションを数量でフィルタリングするためのヒントを教えてもらえますか?

私も試しました:

$stockCollection = Mage::getModel('cataloginventory/stock_item')->getCollection()
                             ->addFieldToFilter('qty', array('gt' => 99999999));
$entityIds = array();
foreach ($stockCollection as $item) {
    $entityIds[] = $item->getOrigData('product_id');
}

$_productCollection->addAttributeToFilter('id', array('in' => $entityIds));

entityId 配列は空ですが、$_productCollection はまだ製品を返しますか?!

4

1 に答える 1

5

説明:

2 回目の挑戦で僅差でした。数量フィルターを追加するための特別な方法がありますMage_CatalogInventory_Model_Resource_Stock_Item_Collection

/**
 * Add filter by quantity to collection
 *
 * @param string $comparsionMethod
 * @param float $qty
 * @return Mage_CatalogInventory_Model_Resource_Stock_Item_Collection
 */
public function addQtyFilter($comparsionMethod, $qty)
{
    $methods = array(
        '<'  => 'lt',
        '>'  => 'gt',
        '='  => 'eq',
        '<=' => 'lteq',
        '>=' => 'gteq',
        '<>' => 'neq'
    );
    if (!isset($methods[$comparsionMethod])) {
        Mage::throwException(
            Mage::helper('cataloginventory')->__('%s is not a correct comparsion method.', $comparsionMethod)
        );
    }

    return $this->addFieldToFilter('main_table.qty', array($methods[$comparsionMethod] => $qty));
}

解決:

$stockIds = Mage::getModel('cataloginventory/stock_item')
    ->getCollection()
    ->addQtyFilter('>=', 30)
    ->getAllIds();

$products = Mage::getModel('catalog/product')
    ->getCollection()
    ->addIdFilter($stockIds)
    ->setPageSize(10);
于 2013-08-06T16:44:41.503 に答える