【发布时间】:2013-09-17 16:47:00
【问题描述】:
我在模块升级中使用 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 内部循环并为每个值设置数据。
- 保存前的setId()
当我在 foreach 之后显示对象时,它是只有我的值而没有方法的对象。 Magento 不显示错误和警告。我的模块升级到好版本但数据库表是空的。
在所有教程中解决 id 简单的 Mage::getModel ->setData()->save()
【问题讨论】:
标签: php magento magento-1.7