希望你能帮助我,我想以编程方式为Magento目录推广规则添加嵌套条件,我有以下代码:
$oMainCondition = Mage::getModel('catalogrule/rule_condition_combine')
->setType('catalogrule/rule_condition_combine')
->setAggregator('all');
$oFirstCondition = Mage::getModel('catalogrule/rule_condition_combine')
->setType('catalogrule/rule_condition_combine')
->setAggregator('any');
$oProdCondition1 = Mage::getModel('catalogrule/rule_condition_product')
->setType('catalogrule/rule_condition_product')
->setAttribute('sku')
->setOperator('==')
->setValue("2595040015");
$oProdCondition2 = Mage::getModel('catalogrule/rule_condition_product')
->setType('catalogrule/rule_condition_product')
->setAttribute('sku')
->setOperator('==')
->setValue("2595040019");
$oFirstCondition->addCondition($oProdCondition1);
$oFirstCondition->addCondition($oProdCondition2);
$oMainCondition->addCondition($oFirstCondition);
$oCatalogPriceRule->getConditions()->addCondition($oMainCondition);
我想实现以下目标: 一个主要的组合条件,条件ALL 这个主要的组合条件将有一个孩子;条件ANY的组合条件 这个孩子将有2个孩子;产品SKU必须为2595040015或产品SKU必须为2595040019的规则
(注意;我意识到在这种情况下,使它成为嵌套条件还没有意义,但我希望在使代码更复杂之前使其工作)
但;使用上面的代码,仅创建以下内容:
1个主要组合条件,条件为ALL 1个孩子结合条件,同样条件ALL(而不是任何)
关于我的产品SKU的2条规则根本没有回到后端。
任何人都知道我在这里做错了什么?
答案 0 :(得分:1)
您需要使用此块:
$item_found = Mage::getModel('salesrule/rule_condition_product_found')
->setType('salesrule/rule_condition_product_found')
->setValue(1) // 1 == FOUND
->setAggregator('all'); // match ALL conditions
$rule->getConditions()->addCondition($item_found);
$conditions = Mage::getModel('salesrule/rule_condition_product')
->setType('salesrule/rule_condition_product')
->setAttribute('sku')
->setOperator('==')
->setValue($sku);
$item_found->addCondition($conditions);
希望这会有所帮助。我使用相同的方法来创建这样的规则。