小编MJA*_*MJA的帖子

在Magento中多次调用$ model-> save()覆盖数据

我正在开发一个自定义Magento模块,需要将电子邮件地址列表保存到自定义表中.相关代码如下所示:

foreach($this->getNewSubscriptionsForAPI() as $email){
            $requestModel->setEmail($email);
            $requestModel->setAction('subscribe');
            $requestModel->setPosted(date('Y-m-d H:i:s'));
            $requestModel->save();
        }
Run Code Online (Sandbox Code Playgroud)

getNewSubscriptionsForAPI()方法返回有效数据,并且$requestModel是有效的Magento模型.

但是,当此循环运行时,数据库适配器会简单地覆盖前一个记录之上的每个记录.即,如果我在phpMyAdmin中反复点击'browse',我可以看到不同的电子邮件地址被写入数据库但总是在同一行,覆盖了前一个条目.正确设置了id字段:作为主键,设置为AUTO_INCREMENT,并在资源模型中标记为id字段.

有趣的是,我可以使用上面的循环在核心newsletter/subscriber表中编写连续记录而没有任何问题.

当然,我可以简单地unset()将模型从Mage::getModel()循环的每个循环中取回,但是这(a)似乎非常浪费,并且(b)破坏了我的依赖注入设置以进行测试(我不想要的地方)要实例化自己的模型的代码,但使用我传递给它的那些代码.

谁能指出我正确的方向?

php magento

8
推荐指数
2
解决办法
7763
查看次数

标签 统计

magento ×1

php ×1