Как добавитьAttributeToFilter AND и OR одновременно? - PullRequest
1 голос
/ 21 марта 2011

Я бы хотел создать фильтр, который выглядит следующим образом:
(псевдокод)

SELECT * FROM Products WHERE 
   (`attribute_foo` LIKE 'bar' AND `attribute_bar` LIKE 'foo')
OR (`attribute_far` LIKE 'boo');

Я знаю, как построить условие OR, предоставив массив, но не оба.

спасибо

Ответы [ 2 ]

2 голосов
/ 22 марта 2011
"from"=>$fromValue, "to"=>$toValue
"like"=>$likeValue
"neq"=>$notEqualValue
"in"=>array($inValues)
"nin"=>array($notInValues)
"eq"=>$equal
"nlike"=>$notlike
"is"=>$is
"gt"=>$greaterthan
"lt"=>$lessthan
"gteq"=>$greterthanequal
"lteq"=>$lessthanequal
"finset"=>$unknown
"date"=>true, "to" => $now

$collection = Mage::getResourceModel('customer/customer_collection')
        ->addNameToSelect()
        ->addAttributeToSelect('email')
        ->addAttributeToSelect('created_at')
        ->addAttributeToSelect('group_id')
        ->addFieldToFilter('entity_id', array('from'=>20, 'to'=>30))
        ->addFieldToFilter('name', array('like'=>'%cindy%'));
0 голосов
/ 22 марта 2011

Вы можете использовать объект данных Magento для фильтрации:

$product = Mage::getModel('catalog/product')
    ->getCollection()
    ->addAttributeToFilter("attribute_code", $value);

print_r($product->getItems());
...