侧边栏壁纸
博主头像
落叶人生博主等级

走进秋风,寻找秋天的落叶

  • 累计撰写 130562 篇文章
  • 累计创建 28 个标签
  • 累计收到 9 条评论
标签搜索

目 录CONTENT

文章目录

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

2022-07-14 星期四 / 0 评论 / 0 点赞 / 40 阅读 / 2606 字

本文实例讲述了Yii2.0框架模型多表关联查询。分享给大家供大家参考,具体如下:联表查询--hasMany:use app/models/User;$right = Right::findOne(2);//$user =

本文实例讲述了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程序设计有所帮助。

广告 广告

评论区