0

我有以下表格:

        echo $this->Form->input('Person.name');
        echo $this->Form->input('Person.phone');
        echo $this->Form->input('Person.email');
        echo $this->Form->input('Message.0.plainmsg');
        echo $this->Form->submit('Send Message');
        echo $this->Form->end();

Person有很多Message

我想设置控制器,以便第一次填写表格并插入PersonMessage但第二次有人用相同的电子邮件地址填写表格时,Person只是更新但新Message的就像以前一样插入。

这是我的控制器到目前为止的样子:

    if ($this->request->is('post')) {

        // Check to see if submitted email address is already
        // a record in Person model
        $person = $this->Person->findByEmail($this->request->data['Person']['email']);

        if ($person) {
            // Set the ID (save query will be UPDATE)
            $this->Person->id = $person['Person']['id'];
        } else {
            // Create a new record (save query will be INSERT)
            $this->Person->create();
        }

        // Save the data (will run as UPDATE or INSERT
        // depending on above
        $this->Person->save($this->request->data);
    }

这一切都按预期工作:如果Person.email已经存在,则Person更新而不是插入。这正是我想要的。

问题是我无法弄清楚如何解决Message所有这些问题。

我尝试将保存更改为蛋糕手册本节$this->Person->saveAssociated($this->request->data)最后一个示例中所示的内容,但结果是蛋糕尝试插入而不是更新它。Person

我在这里尝试做的重点和目的是允许用户发布无限数量的新消息,Message并始终Person使用他们当前的联系号码更新他们的记录(这将定期更改)。

4

1 回答 1

1

您应该saveMessage在消息模型中使用参数$personId$messageText. 此方法的逻辑是将您的新消息与所属用户一起保存。

在您创建或更新人员$this->Person->id后,人员 ID 将被保留。Person::save()

在这种情况下,我不会使用任何蛋糕魔法。

于 2012-06-25T11:43:59.153 回答