web-dev-qa-db-ja.com

プログラムでMagento属性を更新する

属性add_ten_penceを更新するスクリプトを作成しています。属性はyes/noブール値です。現時点では、データベースの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 "\n".'updating '.$_product->getSku()."...\n";
    $product = Mage::getModel('catalog/product')->load($_product->getEntityId());
    $product->setAddTenPence(true);
    $product->save();
}
8
iamgraeme

商品コレクション全体ではなく、単一の属性を保存してみてください。

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 !)

28
seanbreeden