Ответ 1
При использовании таблицы соединений для отношений "многие ко многим" вы должны
- Определить отношения
- Свяжите две модели вместе
В модели пользователя определите следующую функцию отношения:
public function getMarkets() {
return $this->hasMany(Market::className(), ['id' => 'market_id'])
->viaTable('tbl_user_market', ['user_id' => 'id']);
}
В модели рынка определите следующую функцию отношения:
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