我在模块升级中使用 Mage::getModel 在数据库中保存记录有问题。
安装我的模块后,我想将附属程序添加到affiliateplus 模块表中。我的模块覆盖了affiliateplus 模块。
在 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 内部循环和每个值的 setData。
- 保存前的 setId()
当我在 foreach 之后显示对象时,它是只有我的值而没有方法的对象。Magento 不显示错误和警告。我的模块升级到好版本但在数据库表是空的。
在所有教程中解决 id 简单 Mage::getModel ->setData()->save()