我一直在编写一个更新我的属性add_ten_pence的脚本,该属性是一个是/否布尔值.目前它通过数据库中的SKU,但不幸的是它没有更新数据库.我已粘贴下面的脚本有谁知道我哪里出错了?
该属性默认设置为“否”,我希望在脚本运行时将其更改为“是”,反之亦然.
require_once('app/Mage.PHP'); umask(0); Mage::app('default'); Mage :: app ()->setCurrentStore(Mage_Core_Model_App :: ADMIN_STORE_ID); $productCollection = Mage::getModel('catalog/product')->getCollection(); foreach($productCollection as $_product) { echo "\n".'updating '.$_product->getSku()."...\n"; $product = Mage::getModel('catalog/product')->load($_product->getEntityId()); $product->setAddTenPence(true); $product->save(); }
尝试保存单个属性而不是整个产品集合.
require_once('app/Mage.PHP'); umask(0); Mage::app('default'); Mage::app ()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID); $productCollection = Mage::getModel('catalog/product')->getCollection(); foreach($productCollection as $_product) { echo "\n".'updating '.$_product->getSku()."...\n"; $_product->setData('add_ten_pence',1)->getResource()->saveAttribute($_product,'add_ten_pence'); }
UPDATE
更快的方式:
$productCollection = Mage::getModel('catalog/product')->getCollection(); $array_product = $productCollection->getAllIds(); Mage::getSingleton('catalog/product_action')>updateAttributes($array_product,array('add_ten_pence' => 1),Mage_Core_Model_App::ADMIN_STORE_ID);