Как мне работать с отношениями «многие ко многим» в Yii2

Например, один-ко-многим из-за документации (http://www.yiiframework.com/doc-2.0/guide-db-active-record.html#relational-data) вы можете связать две модели таким образом (one-many = company-zone):

$defaultZone = new Zone;
$defaultZone->name = Zone::DEFAULT_ZONE;
$company->link('zones', $defaultZone);

Но как это работает для отношений «многие ко многим», когда у вас есть транзитная таблица, такая как tbl_user_market(user_id, market_id)?

33

Решение

При использовании соединительной таблицы для отношений «многие ко многим» необходимо

  1. Определите отношения
  2. Свяжите две модели вместе

В модели User определите следующую функцию отношения:

public function getMarkets() {
return $this->hasMany(Market::className(), ['id' => 'market_id'])
->viaTable('tbl_user_market', ['user_id' => 'id']);
}

В модели Market определите следующую функцию отношения:

public function getUsers() {
return $this->hasMany(User::className(), ['id' => 'user_id'])
->viaTable('tbl_user_market', ['market_id' => 'id']);
}

И, наконец, после сохранения обеих моделей свяжите их вместе:

$user = new User;
$user->name = 'Foo';
$user->save();

$market = new Market;
$market->name = 'Bar';
$market->save();

$user->link('markets', $market);

Призыв к link() заполнит распределительную таблицу.

Ссылка: http://www.yiiframework.com/doc-2.0/yii-db-baseactiverecord.html#link()-detail

70

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]