我是 Magento 的新手,我创建了我的代码以删除特价商品 并为SKU增加新价格。
我可以删除特价,但我无法为SKU添加新价格。怎么办呢?
我的代码如下:
$productIds[][] = array('DF-12''200','DF-98''300','DF-87''400');
$products = Mage::getResourceModel('catalog/product_collection')
->addAttributeToSelect('*') // <- careful with this
->addAttributeToFilter(
'sku', array('in' => $productIds[0])
)
->load();
foreach ($products as $_product){
$product = Mage::getModel('catalog/product')->load($_product->getId());
$product->setprice($productIds[1])
$product->setOffertext('');
$product->setSpecialFromDate('');
$product->setSpecialToDate('');
$product->setSpecialPrice('');
$product->save();
}
答案 0 :(得分:0)
我不太确定你是如何形成包含你的产品的阵列的&#39; SKU和价格,似乎对我而言。但由于我只能根据给定的信息推测该部分,因此我以编程方式更新较小的产品集合的示例可能会提供更多帮助。这段代码在后端模型中适用于我:
// array('sku' => price )
$productPricesBySku = array('DF-1234' => 180.00, 'DF-1235' => 99.95);
$collection = Mage::getModel('catalog/product')->getCollection()
->addAttributeToSelect('price') // optional
->addAttributeToSelect('special_from_date') // optional
->addAttributeToSelect('special_to_date') // optional
->addAttributeToFilter('sku', array('in'=>array_keys($productPricesBySku)));
foreach($collection as $_product){
if(!($price=$productPricesBySku[$_product->getSku()])) continue;
// no need to load the product again
// just set the data directly on our collection-item and save it
$_product->setPrice((float)$price)
->setSpecialFromDate('')
->setSpecialToDate('')
->setSpecialPrice('')
->save();
}
(为了防止大型集合中的内存耗尽,您应该使用 Mage_Core_Model_Resource_Iterator 而不是foreach循环。例如,您可以阅读here。)