CakePHP сохранение данных HABTM

У меня 2 модели,Client а такжеSecurity, Они связаны с отношениями HATBTM. Я сделал таблицу соединений под названиемclients_securities, Так чтоClient может иметь много ценных бумаг иSecurity может принадлежать многимClients.

Вот мои определения отношений:

 //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,
        )
);

Затем я произвел действие редактирования в моем контроллере клиентов и сделал это:

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'));
        }
    }

В моем редактируемом виде я создаю форму, используя HtmlHelper, добавляя поля таблицы клиента и генерируя множественный выбор с помощью:

echo $this->Form->create('Client'); //start the form for the client model
echo $this->Form->input('Security'); //generates a multi-select popuplated with securities

Кроме того, у меня также есть нормальные прямые формы ввода дляClient в той же форме. например

echo $this->Form->input('name'); //Input for the client name
echo $this->Form->input('currency'); //Input for the client currency
...

Все эти входные данные генерируются и заполняются правильными значениями при визуализации формы, но сохраняются только прямые данные клиента, а не данные HABTM из множественного выбора.

Когда я отправляю формуclients_securities таблица не заполнена идентификаторами соединений.

Что мне нужно сделать, чтобы сохранить его правильно и затем предварительно выбрать сохраненные ценные бумаги при перезагрузке представления «редактировать».

Изменить: чтобы уточнить вещи, вотpr() из$this->request->data, (Значения («ALLCMCT LX Equity») являются правильными внешними ключами дляsecurities Таблица):

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
                )

        )

)

Итак, по сути, скажем, мой идентификатор клиента был 12345, Cake должен вставить 2 записи вclients_securities стол вроде так:

id | client_id | security_id
----------------------------
1  | 12345     | ALLCMCT LX Equity
2  | 12345     | APMKNTD LX Equity

Если я вручную добавлю несколько записей вclients_securitiesКогда я иду к редактированию клиента, ценные бумаги в мульти-выборе корректно выбираются заранее, показывая, что данные считываются из таблицы соединений. Когда я сохраняю форму, она фактически удаляет объединенные записи, но не сохраняет новые.

Дополнительное примечание:Мои идентификаторы безопасности хранятся как CHAR (36) если это имеет какое-либо влияние. Это не поле автоинкремента, оно содержит тикер безопасности, и каждое из них уникально.

Ответы на вопрос(6)

Ваш ответ на вопрос