我一直在编写一个更新我的属性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);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。