CakePHP 3.x:保存多条记录

时间:2015-05-04 22:28:09

标签: cakephp cakephp-3.0

我看过Converting Multiple Records。现在我正试图从表单中一次保存多张照片。

使用:

debug($this->request->data);

我有这个:

[
    (int) 1 => [
        'filename' => '25483_106728809362869_5795827_n.jpg',
        'description' => '',
        'album_id' => '2'
    ],
    (int) 3 => [
        'filename' => '44569_193398817463220_816845208_n.jpg',
        'description' => '',
        'album_id' => '1'
    ]
]

似乎没问题。

Bake为我创造了这个动作方法:

public function add() {
        $photo = $this->Photos->newEntity();

        if($this->request->is('post')) {
            $photo = $this->Photos->patchEntity($photo, $this->request->data);

            if($this->Photos->save($photo)) {
                return $this->redirect(['action' => 'index']);
            }
        }

        $this->set(compact('photo'));
    }

但CakeBook并没有很好地解释如何继续。我觉得我必须使用newEntities()patchEntities(),但我不太明白该怎么做。

例如:为什么newEntity()方法可以接受NULL,而方法newEntities()必然需要参数? save()方法一次只接受一个实体?那么,我必须为每个实体循环保存?

我可以举一个小例子吗?感谢。

2 个答案:

答案 0 :(得分:8)

假设您的数据格式正确,它应该像这样简单:

$photos = $this->Photos->newEntities($this->request->data());

foreach ($photos as $photo) {
    $this->Photos->save($photo);
}

newEntity()可以接受null,因为在没有数据的情况下调用newEntity可以创建一个可以添加数据的空白实体,以防您不想传入请求数据。例如:

$photo = $this->Photos->newEntity();
$photo->description = 'Cool!';
$photo->filename = 'example.jpg';

$this->Photos->save($photo);
但是,如果你想制作许多实体,

newEntities()需要多个数据或至少一个数据数组。

答案 1 :(得分:1)

使用saveMany:

在某些情况下,使用不再需要foreach循环的saveMany会更好。

    $entities = $this->Photos->newEntities($this->request->data());
    if($this->Photos->saveMany($entities)) {
        // saved
    } else { 
        // error
    }