web-dev-qa-db-ja.com

Yii2で多対多のリレーションを使用するにはどうすればよいですか

たとえば、ドキュメントによる1対多の場合( http://www.yiiframework.com/doc-2.0/guide-db-active-record.html#relational-data )リンクできますこのように2つのモデル_(one-many = company-zone)_:

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

しかし、tbl_user_market(user_id, market_id)のようなトランジットテーブルがある場合、多対多のリレーションに対してどのように機能しますか?

35
raiym

多対多のリレーションにジャンクションテーブルを使用する場合、以下を行う必要があります。

  1. 関係を定義する
  2. 2つのモデルをリンクする

Userモデルで、次の関係関数を定義します。

_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

76
vim