iam*_*eme 8 php magento magento-1.7
我一直在编写一个更新我的属性的脚本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 "\n".'updating '.$_product->getSku()."...\n";
$product = Mage::getModel('catalog/product')->load($_product->getEntityId());
$product->setAddTenPence(true);
$product->save();
}
Run Code Online (Sandbox Code Playgroud)
sea*_*den 28
尝试保存单个属性而不是整个产品集合.
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');
}
Run Code Online (Sandbox Code Playgroud)
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);
Run Code Online (Sandbox Code Playgroud)
(谢谢https://magento.stackexchange.com/users/146/marius!)
归档时间: |
|
查看次数: |
27750 次 |
最近记录: |