以编程方式更新Magento属性

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了以编程方式更新Magento属性相关的知识,希望对你有一定的参考价值。

我一直在编写一个更新我的属性add_ten_pence的脚本,该属性是一个是/否布尔值。目前它通过数据库中的SKU's但不幸的是它没有更新数据库。我已粘贴下面的脚本有谁知道我哪里出错了?

该属性默认设置为“否”,我希望在脚本运行时将其更改为“是”,反之亦然。

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 "
".'updating '.$_product->getSku()."...
";
    $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 'updating ' . $_product->getSku() . PHP_EOL;
    $product->setData('add_ten_pence', 1);
    $product->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!)

以上是关于以编程方式更新Magento属性的主要内容,如果未能解决你的问题,请参考以下文章

Magento - 如何以编程方式取消选中超级产品属性上的“使用默认值”?

以编程方式在 Magento 中设置订阅者状态

显示/隐藏片段并以编程方式更改可见性属性

magento 以编程方式为可配置产品创建订单

如何以编程方式比较magento版本?

如何以编程方式通过 Main Activity 在 ViewPager 中更新刷新片段