脚本应该在数据库中创建3个条目,但我只得到一个是最后一个条目。
在我看来,save()方法只执行一次,但它不是假设运行3次,而是在for循环中运行吗?
public function saveAction()
{
$vars = $this->getRequest()->getPost();
var_dump($vars);
$model = mage::getModel('cevent/cevent');
for($i=0;$i<=2;$i++){
$data = array(
'master_customer_id' => $vars['master_customer_id'][$i],
'customer_id' => 'null',
'email' => $vars['email'][$i],
'firstname' => $vars['firstname'][$i],
'surname' => $vars['surname'][$i],
'address' => $vars['address'][$i],
'city' => $vars['city'][$i]
);
$model->addData($data);
$model->save();
}
}
从数据库表单发布数据
array
'master_customer_id' =>
array
0 => string '1' (length=1)
1 => string '1' (length=1)
2 => string '1' (length=1)
'firstname' =>
array
0 => string 'q' (length=1)
1 => string 'w' (length=1)
2 => string 'e' (length=1)
'surname' =>
array
0 => string 'q' (length=1)
1 => string 'w' (length=1)
2 => string 'e' (length=1)
'email' =>
array
0 => string 'q' (length=1)
1 => string 'w' (length=1)
2 => string 'e' (length=1)
'address' =>
array
0 => string 'Invercagille' (length=12)
1 => string 'Invercagille' (length=12)
2 => string 'Invercagille' (length=12)
'city' =>
array
0 => string 'q' (length=1)
1 => string 'w' (length=1)
2 => string 'e' (length=1)
DB只显示一个条目
请提出建议或有任何其他方法。谢谢
答案 0 :(得分:1)
你的第一个循环创建了一个对象,而下一个循环都在更新同一个对象。
您必须在每个循环中重置对象才能创建新对象。
不使用object->addData()
,而是使用object->setData()
代替新版本的所有数据(并在后台删除存储在对象数据中的上一次保存的primary_key)。
答案 1 :(得分:1)
Magento的ORM使用save()
进行创建和更新操作。主键的存在是资源模型层用于确定是执行插入还是更新的内容。在第一次迭代期间保存对象数据时会插入它,但随后会在$model
引用的实例上设置自动增量主键,之后您将只获得更新。您可以取消设置数据或在for
循环中重新实例化该类,并完成多次插入。