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

rai*_*iym 35 php many-to-many 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);
Run Code Online (Sandbox Code Playgroud)

但是当你有转机表时,它如何适用于多对多关系tbl_user_market(user_id, market_id)

vim*_*vim 77

当使用联结表来实现多对多关系时,您必须这样做

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

在User模型中定义以下关系函数:

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

在市场模型中定义以下关系函数:

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

最后,保存两个模型后,将它们链接在一起:

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

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

$user->link('markets', $market);
Run Code Online (Sandbox Code Playgroud)

调用link()将填充联结表.

参考:http://www.yiiframework.com/doc-2.0/yii-db-baseactiverecord.html#link()-detail

  • 您还可以使用ManyToMany行为.请参阅:https://github.com/voskobovich/ManyToManyBehavior (3认同)
  • 我创建了一种行为来帮助保存多个链接 - http://github.com/cornernote/yii2-linkall `User::findOne(1)->linkAll('markets', [Market::findOne(2), Market: :findOne(3)], true);`,它会在删除旧链接并添加新链接后进行查找。 (2认同)