为什么save方法只在for循环中执行一次?

时间:2013-04-08 12:07:38

标签: magento

脚本应该在数据库中创建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只显示一个条目

enter image description here

请提出建议或有任何其他方法。谢谢

2 个答案:

答案 0 :(得分:1)

你的第一个循环创建了一个对象,而下一个循环都在更新同一个对象。

您必须在每个循环中重置对象才能创建新对象。

不使用object->addData(),而是使用object->setData()代替新版本的所有数据(并在后台删除存储在对象数据中的上一次保存的primary_key)。

答案 1 :(得分:1)

Magento的ORM使用save()进行创建和更新操作。主键的存在是资源模型层用于确定是执行插入还是更新的内容。在第一次迭代期间保存对象数据时会插入它,但随后会在$model引用的实例上设置自动增量主键,之后您将只获得更新。您可以取消设置数据或在for循环中重新实例化该类,并完成多次插入。