- 时间:2022-08-05 20:45 编辑: 来源: 阅读:
- 扫一扫,手机访问
摘要:Yii2中多表关联查询hasOne hasMany的方法
表positionContent
| id |
position_id |
content_title |
content_id |
is_recommend |
list_sort |
update_time |
create_time |
| 10 |
14 |
大成成长 |
160910 |
1 |
1 |
2017-02-09 11:51:56 |
2017-02-09 11:51:56 |
| 11 |
15 |
创新成长 |
160910 |
1 |
1 |
2017-02-09 11:52:08 |
2017-02-09 11:52:08 |
position表
| id |
name |
title |
type |
num |
remark |
update_time |
create_time |
| 14 |
列表推荐一 |
五星推荐 |
1 |
3 |
|
2017-02-09 00:00:00 |
2017-02-09 00:00:00 |
| 15 |
列表推荐二 |
热销基金 |
1 |
4 |
|
2017-02-09 00:00:00 |
2017-02-09 00:00:00 |
positionContent表的position_id对就position表的id。positionContent跟position是一对一的关系,反过来则是多对一。
[b]model[/b]
class PositionContent extends \yii\db\ActiveRecord
{
...
public function getPosition(){
return $this->hasOne(Position::className(), ['id'=>'position_id']);
}
...
然后在Controller调用,这样就能拿到position表中的数据了。
class TestController extends BackendBaseController
{
public function actionIndex()
{
$data = PositionContent::findOne(10);
$position = $data->position;
}
}
其实hasOne是执行了两次查询,并不是真正的连表查询。
SELECT * FROM `position_content` WHERE `id`=10
SELECT * FROM `position` WHERE `id`='14'
以上所述是小编给大家介绍的Yii2中多表关联查询hasOne hasMany,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!