Cómo trabajo con relaciones de muchos a muchos en Yii2


Por ejemplo en uno-a-muchos, debido a la documentación (http://www.yiiframework.com/doc-2.0/guide-db-active-record.html#relational-data) puede vincular dos modelos de esta manera (one-many = company-zone):

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

Pero, ¿cómo funciona para las relaciones de muchos a muchos cuando se tiene una tabla de tránsito como tbl_user_market(user_id, market_id)?

Author: johnsnails, 2014-11-05

1 answers

Cuando se utiliza una tabla de unión para relaciones de muchos a muchos, hay que

  1. Definir las relaciones
  2. Vincular los dos modelos juntos

En el modelo User defina la siguiente función de relación:

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

En el modelo de mercado defina la siguiente función de relación:

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

Y finalmente, después de guardar ambos modelos, enlázalos juntos:

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

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

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

La llamada a link() llenará la tabla de conexiones.

Referencia: http://www.yiiframework.com/doc-2.0/yii-db-baseactiverecord.html#link () - detalle

 68
Author: vim,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2014-11-06 14:32:21