例如,由于文档(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)
?
当使用联结表进行多对多关系时,您必须
在用户模型中,定义以下关系函数:
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
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句