CakePHP3.4: не понимаю ошибку при сохранении ассоциации ownToMany

Я пытаюсь ввести belongsToMany ассоциация в форме, но довольно специфическое описание ассоциации.
Потому что моя сущность Site Я могу использовать языки для 2 разных видов использования, я использую 2 таблицы соединения.
Итак, схема следующая

Relationship                        Join Table Fields
Sites belongsToMany Vislanguages    sites_vislanguages.id, sites_vislanguages.language_id, sites_vislanguages.site_id
Relationship                        Join Table Fields
Sites belongsToMany Reclanguages    sites_reclanguages.id, sites_reclanguages.language_id, sites_reclanguages.site_id

Итак Table классы:

class VislanguagesTable extends Table {

    public function initialize(array $config) {
        parent::initialize($config);

        $this->table('languages');
        $this->displayField('name_fr');
        $this->primaryKey('id');

        $this->belongsToMany('Sites', [
            'foreignKey' => 'language_id',
            'targetForeignKey' => 'site_id',
            'joinTable' => 'sites_vislanguages',
        ]);

    }
}

class SitesTable extends Table {

public function initialize(array $config) {
    parent::initialize($config);

    $this->belongsToMany('Reclanguages', [
        'joinTable' => 'sites_reclanguages',
        'className' => 'Languages',
        'propertyName' => 'reclanguages'
    ]);

    $this->belongsToMany('Vislanguages', [
        'joinTable' => 'sites_vislanguages',
        'className' => 'Languages',
        'propertyName' => 'vislanguages'
    ]);

}

класс SitesVislanguagesTable расширяет таблицу {

public function initialize(array $config) {
    parent::initialize($config);

    $this->table('sites_vislanguages');
    $this->displayField('id');
    $this->primaryKey('id');

    $this->belongsTo('Sites', [
        'foreignKey' => 'site_id',
    ]);
    $this->belongsTo('Languages', [
        'foreignKey' => 'language_id',
    ]);
}

У меня конечно есть проблема для add а также edit формы, но я здесь беру пример edit, Если я find() готовый siteструктура данных:

object(App\Model\Entity\Site) {

    'id' => (int) 23098,
    'Vislanguages' => [
        (int) 0 => object(App\Model\Entity\Language) {

            'id' => (int) 1,
            '_joinData' => object(App\Model\Entity\SitesVislanguage) {

                'id' => (int) 4409,
                'site_id' => (int) 23098,
                'language_id' => (int) 1,
                ...,
                '[repository]' => 'SitesVislanguages'

            },
            ...,
            '[repository]' => 'Vislanguages'

        },
        (int) 1 => object(App\Model\Entity\Language) {

            'id' => (int) 9,
            '_joinData' => object(App\Model\Entity\SitesVislanguage) {

                'id' => (int) 4410,
                'site_id' => (int) 23098,
                'language_id' => (int) 9,
                ...,
                '[repository]' => 'SitesVislanguages'

            },
            ...,
            '[repository]' => 'Vislanguages'

        }
    ],
    ...,
    '[repository]' => 'Sites'

}

И мой соответствующий ctp файл:

<?= $this->Form->control('vislanguages._ids', ['options' => $languages, 'label' => __('Spoken languages:'), 'multiple' => true]); ?>

Языки правильно выбраны во входных данных. Если я отправлю его без каких-либо изменений, исправленная сущность будет:

объект (App \ Model \ Entity \ Site) {

'id' => (int) 23098,
...,
'vislanguages' => [
    (int) 0 => object(App\Model\Entity\Language) {

        'id' => (int) 1,
        ...,
        '[repository]' => 'Vislanguages'

    },
    (int) 1 => object(App\Model\Entity\Language) {

        'id' => (int) 9,
        ...,
        '[repository]' => 'Vislanguages'

    }
],
'[repository]' => 'Sites'

}

Что кажется правильным, но когда я сохраняю его, я получаю следующую ошибку:

Error: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'vislanguage_id' in 'where clause' 

Запрос:

(SELECT SitesVislanguages.id AS `SitesVislanguages__id`, SitesVislanguages.site_id AS `SitesVislanguages__site_id`, SitesVislanguages.language_id AS `SitesVislanguages__language_id` FROM sites_vislanguages SitesVislanguages WHERE (site_id = :c0 AND vislanguage_id = :c1))
UNION (SELECT SitesVislanguages.id AS `SitesVislanguages__id`, SitesVislanguages.site_id AS `SitesVislanguages__site_id`, SitesVislanguages.language_id AS `SitesVislanguages__language_id` FROM sites_vislanguages SitesVislanguages WHERE (site_id = :c2 AND vislanguage_id = :c3))

Почему мы видим vislanguage_id в WHERE пункт, тогда как он правильно считает language_id вместо этого в SELECT пункт?

В то же время я не очень понимаю UNION Вот.

1 ответ

Решение

Чтобы заставить его работать, я должен был указать targetForeignKey:

class SitesTable extends Table {

public function initialize(array $config) {
    parent::initialize($config);

    $this->belongsToMany('Reclanguages', [
        'targetForeignKey' => 'language_id,
        'joinTable' => 'sites_reclanguages',
        'className' => 'Languages',
        'propertyName' => 'reclanguages'
    ]);

    $this->belongsToMany('Vislanguages', [
        'targetForeignKey' => 'language_id,
        'joinTable' => 'sites_vislanguages',
        'className' => 'Languages',
        'propertyName' => 'vislanguages'
    ]);

}
Другие вопросы по тегам