web-dev-qa-db-fra.com

Comment travailler avec des relations plusieurs-à-plusieurs dans Yii2

Par exemple dans un à plusieurs en raison de la documentation ( http://www.yiiframework.com/doc-2.0/guide-db-active-record.html#relational-data ) vous pouvez lier deux modèles de cette façon (one-many = company-zone):

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

Mais comment cela fonctionne-t-il pour les relations plusieurs-à-plusieurs lorsque vous avez une table de transit comme tbl_user_market(user_id, market_id)?

35
raiym

Lorsque vous utilisez une table de jonction pour des relations plusieurs-à-plusieurs, vous devez

  1. Définir les relations
  2. Reliez les deux modèles ensemble

Dans le modèle utilisateur, définissez la fonction de relation suivante:

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

Dans le modèle de marché, définissez la fonction de relation suivante:

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

Et enfin, après avoir enregistré les deux modèles, reliez-les ensemble:

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

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

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

L'appel à link() remplira la table de jonction.

Référence: http://www.yiiframework.com/doc-2.0/yii-db-baseactiverecord.html#link () -detail

76
vim