我正在开发一个自定义 Magento 模块,该模块需要将电子邮件地址列表保存到自定义表中。相关代码如下所示:
foreach($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 中反复点击“浏览”,我可以看到不同的电子邮件地址被写入数据库,但总是在同一行中,从而覆盖先前的条目。id 字段设置正确:作为主键,设置为 AUTO_INCREMENT,并在资源模型中标记为 id 字段。
有趣的是,我可以使用上面的循环在核心newsletter/subscriber
表中写入连续的记录,没有问题。
当然,我可以简单地unset()
建立模型并将其从Mage::getModel()
循环的每个循环中取出,但这(a)似乎非常浪费,并且(b)破坏了我的依赖注入设置以进行测试(我不希望代码实例化自己的模型,但使用我传递给它的模型)。
谁能指出我正确的方向?