如何同时在多个表中创建新记录?

时间:2010-07-17 08:09:35

标签: model-view-controller cakephp cakephp-1.3

我想知道如何实现一个允许用户在相关模型中输入多个(未知)记录数的视图。

例如,我有两个模型叫做组和用户。我想实现一个允许我创建一个组的视图(这很容易),并且在同一视图中让我创建属于该组的多个用户。

我希望我的问题很明确,如果不是让我知道......

2 个答案:

答案 0 :(得分:1)

在后端,使用saveAll($ data),准备您的数据,如:

// Prepare the data for the Group hasMany User
$data = array('Group' => array(
                'id' => 5, 
                'name' => 'my group',
                'User' => array(
                  array('id'=>1,'username' => 'john'),
                  array('id'=>2,'username' => 'pachelbel'))
                )
              )

// OR if it's being passed in, just use $this->data in place of $data

// Save all the data
$this->Group->saveAll($data)

在视图中,您要准备表单,使其具有正确的数组键:

<form id="GroupCreateForm" method="post" action="/groups/create">
  <input type="hidden" name="data[Group][id]" value="5" />
  <input type="hidden" name="data[Group][name]" value="my group" />
    <input type="hidden" name="data[Group][User][0][id]" value="1" />
    <input type="hidden" name="data[Group][User][0][username]" value="john" />
    <input type="hidden" name="data[Group][User][1][id]" value="2" />
    <input type="hidden" name="data[Group][User][1][username]" value="pachelbel" />
</form>

如果要动态地向表单添加用户,请考虑使用javascript注入新的input元素。

有关详细信息,请参阅this

答案 1 :(得分:1)

使用Cake的Form帮助器可以更聪明地完成。在上面的示例中,您可以像这样重写:

<?php
echo $this->Form->Create('Group');
echo $this->Form->input('Group.id');
echo $this->Form->input('Group.name');
for($i=0;$i<10;$i++){
   $this->Form->input('User.'.$i.'.id');
   $this->Form->input('User.'.$i.'.name');
}
?>

通过这种方式,您可以从自动错误处理以及字段值填充中受益。