1

是否可以对 magento 产品集合的多选属性执行 LIKE 操作?

例如下面我在 set 中进行查找以找到完全匹配:

$_productCollection = Mage::getResourceModel('catalog/product_collection')
->addAttributeToFilter('makemodel',
        array('finset' => Mage::getResourceModel('catalog/product')
                ->getAttribute('makemodel')
                ->getSource()
                ->getOptionId('@Massey Ferguson@#350#')
        )
)
->addAttributeToSelect('*');


if($_productCollection){
    foreach($_productCollection as $product){

        var_dump($product->getData());

    }
}

我想要做的是获取包含@Massey Ferguson@ 的属性选项的选项ID,然后找到具有返回选项ID 的任何产品。

有什么建议么?

4

1 回答 1

2

好的,所以我想出了一种方法来对多选属性选项进行点赞...

$make = $make.'%';
    /** @var $attribute Mage_Eav_Model_Entity_Attribute */
    $valuesCollection = Mage::getResourceModel('eav/entity_attribute_option_collection')
    ->setAttributeFilter($attribute->getId())
    ->addFieldToFilter('value', array ('like' => $make))
    ->addFieldToSelect('option_id')
    ->setStoreFilter(0, false);


$set = array();
foreach($valuesCollection as $option){
    $set[] = $option->getData('option_id');
}

$_productCollection = Mage::getResourceModel('catalog/product_collection')
->addAttributeToFilter('makemodel',
        array('in' => $set
        )
)
->addAttributeToSelect('*');

这似乎工作得很好!如果其他人有可能更好的解决方案,请告诉我。

于 2013-10-19T20:33:08.893 回答