В моем проекте у меня есть две связанные модели: Company
и CompanyComment
. Компания имеетОдна компаниякомментарий.
Теперь, когда я хочу обновить информацию о компании через saveAssociated, я делаю это следующим образом:
Действие контроллера:
public function edit($id = null){
$this->Company->id=$id;
$this->Company->recursive = 0;
if($this->request->is('post')|| $this->request->is('put')){
if($this->Company->saveAssociated($this->request->data)){
$this->Session->setFlash(__('data has been updated'), 'positive_notification');
$this->redirect(array('controller'=>'companies', 'action'=>'overview'));
} else{
$this->Session->setFlash(__('Data has not been updated. '), 'negative_notification');
}
}else{
$this->request->data = $this->Company->read();
}
}
И вид следующий:
<?php echo $this->Form->create('Company', array('enctype' => 'multipart/form-data'));?>
<fieldset>
<?php
echo $this->Form->input('Company.newsletter');
echo $this->Form->input('CompanyComment.comment_1', array('label'=>__('Domas comment')));
echo $this->Form->input('CompanyComment.comment_2', array('label'=>__('Sunny comment')));
?>
</fieldset>
<?php echo $this->Form->end(__('Update'));?>
Вот данные запроса перед сохранением:
array(
'Company' => array(
'newsletter' => '1'
),
'CompanyComment' => array(
'comment_1' => 'comment1',
'comment_2' => 'comment2'
)
)
Но это просто не сохранило бы данные. Любая помощь или руководство очень ценятся.
Вот отношение модели компании:
var $hasOne = 'CompanyComment';
Еще одно замечание: первичный ключ таблицы CompanyComment — это company_id, а не автоматически увеличивающийся идентификатор.