0

我在模块升级中使用 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()

4

2 回答 2

0

很难说,为什么 savin 不起作用。我会

1)清除整个magento缓存

如果这没有帮助,请将记录添加到数据库并尝试加载它,或者使用模型的 setter 方法将单个对象写入数据库。如果您无法加载/保存任何实体,请尝试调试,如果所有的附属程序/程序模型都正确实例化。

于 2013-09-13T05:58:13.710 回答
0

有趣的。如果将 foreach 循环替换为:

foreach($_programList as $_v){
  Mage::getModel('affiliateplusprogram/program')
    ->setData($_v)
    ->save();
}

(没有 unset()),它会工作吗?如果调用退出,我遇到了没有保存模型的问题;紧随 $model->save();

于 2013-09-13T08:11:35.407 回答