>我在模块升级中使用 Mage::getModel 在数据库中保存记录时遇到问题。
我想在安装模块时将会员计划添加到会员加模块表中。我的模块覆盖会员加模块。
在mysql4-upgrade-0.1.3-0.1.4中.php我有代码
$installer = $this;
$installer->startSetup();
$_programList =[
'affiliate'=>[
'program_id'=>1,
'name' =>'Program Afiliacyjny',
'created_date' =>date('Y-m-d'),
'status' =>1,
'expire_time'=>0,
'num_account'=>2,
'total_sales_amount' =>0.00,
'commission_type'=>'precentage',
'commission'=>1,
'discount_type'=>'precentage',
'discount' =>1,
'autojoin' =>1,
'scope' =>0,
'customer_groups' =>null,
'show_in_welcome' =>0,
'valid_from' =>null,
'valid_to' =>null,
'use_coupon' =>0,
'coupon_pattern'=>null ,
'affiliate_type'=>null ,
'description' =>'Program Afiliacyjny',
'conditions_serialized' =>'a:6:{s:4:"type";s:32:"salesrule/rule_condition_combine";s:9:"attribute";N;s:8:"operator";N;s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";}',
'actions_serialized' =>'a:6:{s:4:"type";s:40:"salesrule/rule_condition_product_combine";s:9:"attribute";N;s:8:"operator";N;s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";}',
'is_process' =>0,
'use_tier_config'=>0 ,
'max_level' =>0,
'tier_commission'=>null ,
'sec_commission' =>0,
'sec_commission_type'=>0 ,
'secondary_commission' =>0,
'sec_discount' =>0,
'sec_discount_type'=>null ,
'secondary_discount' =>0,
'customer_group_ids' =>'1',
'use_sec_tier' =>0,
'sec_tier_commission'=>null
],
['more elements...']
];
foreach($_programList as $_v){
$_program = Mage::getModel('affiliateplusprogram/program');
$_program->setData($_v);
$_program->save();
unset($_program);
}
$installer->endSetup();
我也试过:
- foreach 内部循环并为每个值设置数据。
- 保存前的 setId()
当我在foreach之后显示对象时,它是只有我的值而没有方法的对象。Magento不显示错误和警告。我的模块升级到良好版本,但在数据库表中为空。
在所有教程中,解决 id 简单的 Mage::getModel ->setData()->save()
很难这么说,为什么 savin 不起作用。
我会1)清除整个Magento缓存
如果这没有帮助,请将记录添加到数据库并尝试加载它,或者使用模型的 setter 方法将单个对象写入数据库。 如果您无法加载/保存任何实体,请尝试调试,如果所有会员加程序/程序模型都正确实例化。
有趣。如果将foreach循环替换为:
foreach($_programList as $_v){
Mage::getModel('affiliateplusprogram/program')
->setData($_v)
->save();
}
(没有 unset()),它会工作吗?如果呼叫退出,我遇到了一个没有保存模型的问题;紧接着$model->保存();