CakePHP salvando dados HABTM
Eu tenho 2 modelos,Client
eSecurity
. Eles estão associados a um relacionamento do HATBTM. Eu fiz uma tabela de junção chamadaclients_securities
. Então umClient
pode ter muitos títulos e umSecurity
pode pertencer a muitosClient
s.
Aqui estão minhas definições de relacionamento:
//Client Model:
public $hasAndBelongsToMany = array(
'Security' =>
array(
'className' => 'Security',
'joinTable' => 'clients_securities',
'foreignKey' => 'client_id',
'associationForeignKey' => 'security_id',
'unique' => true,
)
);
//Security Model:
public $hasAndBelongsToMany = array(
'Client' =>
array(
'className' => 'Client',
'joinTable' => 'clients_securities',
'foreignKey' => 'security_id',
'associationForeignKey' => 'client_id',
'unique' => true,
)
);
Em seguida, fiz uma ação de edição no controlador de meus clientes e fiz isso:
public function edit($id = null) {
if (!$id) {
throw new NotFoundException(__('Invalid client'));
}
$client = $this->Client->findById($id);
if (!$client) {
throw new NotFoundException(__('Invalid client'));
}
if ($this->request->is('post') || $this->request->is('put')) {
$this->Client->id = $id;
if ($this->Client->saveAll($this->request->data)) {
$this->Session->setFlash(__('Client has been updated.'));
return $this->redirect(array('action' => 'edit', $id));
}
$this->Session->setFlash(__('Unable to update client.'));
}
if (!$this->request->data) {
$this->request->data = $client;
$this->set('securities', $this->Client->Security->find('list'));
}
}
Na minha visualização de edição, eu construo o formulário usando o HtmlHelper, adicionando os campos da tabela do cliente e gerando a seleção múltipla com:
echo $this->Form->create('Client'); //start the form for the client model
echo $this->Form->input('Security'); //generates a multi-select popuplated with securities
Além disso, também tenho entradas de formulário direto normais para oClient
na mesma forma. por exemplo.
echo $this->Form->input('name'); //Input for the client name
echo $this->Form->input('currency'); //Input for the client currency
...
Todas essas entradas são geradas e preenchidas com os valores corretos quando o formulário é renderizado, mas apenas os dados diretos do Cliente são salvos, não os dados do HABTM da seleção múltipla.
Quando eu submeto o formulárioclients_securities
tabela não é preenchida com os IDs de associação.
O que preciso fazer para salvá-lo corretamente e ter os títulos salvos pré-selecionados quando eu recarregar a visualização "editar".
Edit: Para esclarecer as coisas, aqui é umpr()
do$this->request->data
. (Os valores ("ALLCMCT LX Equity") são as chaves estrangeiras corretas para osecurities
mesa):
Array
(
[Client] => Array
(
[id] => 1212
[name] => Example Client
[currency] => GBP
[partner] =>
[risk_category_id] => 4
[client_code_id] => 1
[min_cash_balance] => 0
[active] => 1
[model] => 0
[institutional] => 0
[non_uk_situs] => 0
[reporting_status] => 0
)
[Security] => Array
(
[Security] => Array
(
[0] => .1muslib3 index
[1] => .eurib3 index
[2] => .ukcpi2 index
)
)
)
Então, essencialmente, digamos que meu id de cliente era 12345, Cake deveria inserir 2 registros noclients_securities
mesa assim:
id | client_id | security_id
----------------------------
1 | 12345 | ALLCMCT LX Equity
2 | 12345 | APMKNTD LX Equity
Se eu adicionar manualmente alguns registros de associaçãoclients_securities
, quando vou editar um cliente, os títulos da seleção múltipla aparecem corretamente pré-selecionados, mostrando que os dados estão sendo lidos na tabela de associação. Quando eu salvo o formulário, ele realmente remove os registros de junção, mas não salva novos registros.
Nota adicional:Meus IDs de segurança são armazenados como CHAR (36) se isso tiver algum efeito. Este não é um campo de incremento automático, contém o ticker da segurança e cada um é único.