保存许多现有记录与一条新记录之间的关系



使用CakePHP,我有事件和人物。我想在保存新活动时将许多现有人员分配给我正在创建的活动。我正在使用复选框选择人员。

我的数据如下所示:

data[Event][name]:Test 4
data[Event][event_type_id]:1
data[EventPerson][person_id]:
data[EventPerson][person_id][]:65
data[EventPerson][person_id][]:72
data[EventPerson][person_id][]:67

我有EventPerson模型,设置了彼此之间的HABTM关系,以及一个events_people表和模型,这些模型都设置正确。

我试过$this->Event->saveAssociated$this->Event->saveAll.每个人都会用正确的信息保存事件记录,也不会保存与人的关系。

保存事件时,人们将永远存在。我觉得我错过了一些明显的东西,但我已经绞尽脑汁几个小时了,结果没有变化。

控制器

$this->Event->create();
    if ($this->Event->save($this->request->data)) {
        $this->Session->setFlash(__('The event has been saved'));
        return $this->redirect...
    }
$people= $this->FestivalPerson->find('all', 
    array(
        "Person.name",
        "conditions" => array(
            "festival_id" => $this->request->query["festival_id"]
        ), 
        "order" => "Person.name ASC"
    )
);
$this->set("eventPeople", Set::combine($people, '{n}.Person.id', '{n}.Person.name'));

视图:

echo $this->Form->input('EventPerson', array('multiple' => 'checkbox'));

数据:

data[Event][EventPerson]:
data[Event][EventPerson][]:50
data[Event][EventPerson][]:65
data[Event][EventPerson][]:71

看起来它与每个示例的结构相匹配,应该正确保存,但我的events_people表仍然是空的。PHP/MySQL也没有出现任何错误。

像这样形成你的数据

data[Event][name]:Test 4
data[Event][event_type_id]:1
data[EventPerson][0][person_id]:
data[EventPerson][1][person_id][]:65
data[EventPerson][2][person_id][]:72
data[EventPerson][2][person_id][]:67

或关注这篇文章:http://patisserie.keensoftware.com/en/pages/how-to-save-habtm-data-in-cakephp

它解释了如何在cakePhp中为数据数组编写自定义代码,我相信那里有一个类似的例子

最新更新