php – 以编程方式更新Magento属性
发布时间:2020-12-13 13:52:10 所属栏目:PHP教程 来源:网络整理
导读:我一直在编写一个更新我的属性add_ten_pence的脚本,该属性是一个是/否布尔值.目前它通过数据库中的SKU,但不幸的是它没有更新数据库.我已粘贴下面的脚本有谁知道我哪里出错了? 该属性默认设置为“否”,我希望在脚本运行时将其更改为“是”,反之亦然. require
我一直在编写一个更新我的属性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); (谢谢https://magento.stackexchange.com/users/146/marius!) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |