• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
james1207

博客园    首页    新随笔    联系   管理    订阅  订阅

解决magento保存产品时耗时很长的问题

以前我在更新产品属性值(拿price为例)的时候,通常会这样做:

foreach($product_ids as $id){
    $product = Mage::getModel('catalog/product')->load($id);
    $product->setPrice($price)->save();
}


因为之前网站产品很少,也就几百个,foreach下来,不会感觉这段code很慢,后来产品逐渐增多,每次走到这里,动辄就会消耗几个小时;echo了一下save,每个产品约耗费5秒,如果有1万件产品,foreach完成就是14个小时,mysql都几乎就要gone 掉了;
上网search了一下发现magento有一个直接更新Attribute的function,改code之后为

$store_id = Mage::app()->getStore('default')->getId();
foreach($product_ids as $id){
    Mage::getSingleton('catalog/product_action')->updateAttributes(array($id), array('price'=>$price), $store_id);
}

 

这段code要比前面的节省5倍左右的时间,很好的解决了我的需求。

本文链接http://blog.csdn.net/shangxiaoxue/article/details/10605579

 

posted @ 2013-08-30 17:55  Class Xman  阅读(296)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3