首页 > 编程 > PHP > 正文

Yii2.0框架模型多表关联查询示例

2019-11-21 19:54:39
字体:
来源:转载
供稿:网友

本文实例讲述了Yii2.0框架模型多表关联查询。分享给大家供大家参考,具体如下:

联表查询--hasMany:

use app/models/User;$right = Right::findOne(2);//$user = User::find()->where(['right_id' => $right->attributes['id']])->all();$user = $right->hasMany(User::className(),['right_id' => 'id'])->all();//right_id为User::className()表中字段,id为Right::findOne(2)表字段

多表关联一对多查询优化

如果多次用到同表相同查询:

/models/Rught.php

namespace app/models;use /yii/db/ActiveRecord;class Right extends ActiveRecord{  public function getUsers()  {    $users = $this->hasMany(User::className(),['right_id' => 'id'])->asArray()p->all();    return $users;  }}

/controller/home/actionAbout

public function actionAbout(){  $right = Right::findOne(2);//  $users = $right->getRights();  $users = $right->rights;  dd($users);  return $this->render('about');}

多表关联一对一查询

/models/User.php

namespace app/models;use /yii/db/ActiveRecord;class User extends ActiveRecord{  public function getRight()  {    $right = $this->hasOne(Right::className,['id' => 'right_id'])->asArray();    return $right;  }}

/controller/home/actionAbout

$user = User::findOne(1);$right = $user->user;dd($right);return $this->render('about');

join

//查询关联表的所有数据$user = User->find()->with('right')->asArray()->all();

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表