繁体   English   中英

如何在Yii2中处理多对多关系

[英]How do I work with many-to-many relations in 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)这样的运输表时,它如何用于多对多关系?

当使用联结表进行多对多关系时,您必须

  1. 定义关系
  2. 将两个模型链接在一起

在用户模型中,定义以下关系函数:

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM