我正在开发一个自定义Magento模块,需要将电子邮件地址列表保存到自定义表中.相关代码如下所示:
原文链接:https://www.f2er.com/php/135652.htmlforeach($this->getNewSubscriptionsForAPI() as $email){ $requestModel->setEmail($email); $requestModel->setAction('subscribe'); $requestModel->setPosted(date('Y-m-d H:i:s')); $requestModel->save(); }
getNewSubscriptionsForAPI()方法返回有效数据,$requestModel是有效的Magento模型.
但是,当此循环运行时,数据库适配器会简单地覆盖前一个记录之上的每个记录.即,如果我在PHPMyAdmin中反复点击’browse’,我可以看到不同的电子邮件地址被写入数据库但总是在同一行,覆盖了前一个条目. id字段已正确设置:作为主键,设置为AUTO_INCREMENT,并标记为资源模型中的id字段.
有趣的是,我可以使用上面的循环在核心时事通讯/订阅者表中编写连续记录,没有任何问题.
当然,我可以简单地取消设置()模型并在循环的每个循环中将其从Mage :: getModel()中取出,但这(a)似乎非常浪费,并且(b)破坏了我的依赖注入设置用于测试(我不希望代码实例化自己的模型,但使用我传递给它的模型).
谁能指出我正确的方向?