以编程方式更新Magento属性


Updating Magento Attribute Programmatically

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

属性默认设置为'No',我希望在脚本运行时将其更改为'Yes',反之亦然。

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 'updating ' . $product->getSku() . PHP_EOL;
    $product->setData('add_ten_pence', 1);
    $product->getResource()->saveAttribute($product, 'add_ten_pence');
}

更快的方法:

$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

(谢谢!)