IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> with关联查询的使用,hasOne/hasMany/belongsTo -> 正文阅读

[开发测试]with关联查询的使用,hasOne/hasMany/belongsTo

TP5中 经常要连表查用的是with,with熟练使用可以快速完成编程。

with在controller 中的常见用法:

$data = \app\admin\model\patients\Patients::where("id", $id)
    ->with(["room", "bed", "clinical"])
    ->find();

?同时在model中的Patients.php需要添加:

    public function clinical()
    {
        return $this->hasOne('Clinical', "id", "clinical_id");
    }

    public function room()
    {
        return $this->hasOne('app\admin\model\space\Info', "id", "space_id");
    }

    public function bed()
    {
        return $this->hasOne('app\admin\model\space\Bed', "id", "bed_id");
    }

当然也可以多个表联查,例如:

$data = \app\admin\model\Document::order('type')
    ->where($where)
    ->where('status',1)
    ->with(['file.user','user'])
    ->paginate($pagesize);

在model中的Document.php页面中添加:

    public function file()
    {
        return $this->hasOne(File::class, 'id', 'file_id');
    }
    public function user()
    {
        return $this->hasOne(User::class, 'id', 'user_id')->field("id,username,nickname,prevtime,logintime,jointime");
    }

在model中的File.php页面中添加:

    public function user()
    {
        return $this->hasOne(User::class, 'id', 'user_id')->field("id,username,nickname,prevtime,logintime,jointime");
    }

常见的关联查询的使用:hasOne/hasMany/belongsTo

hasOne:?一对一关联

数据之间的关联一对一。例如:一个file表里面的上传人对应一个user表中的user信息。

hasOne('别的表模型名','别的表外键名','本表主键名',['模型别名定义'],'join类型');

    public function user(){
        return $this->hasOne(User::class, 'id', 'create_id')->field("id,username");
    }

hasMany:?一对多关联

数据之间的关联一对多。例如:一个user表里面的上传文件对应file表中的多个file。?

?withcount用法:

$rows = \app\admin\model\UserGroup::where($map)
    ->with(['department','user'])
    ->withCount('linkUser')
    ->paginate($pageSize);
    public function department(){
        return $this->belongsTo(Department::class,"department_id","id")->field('id,name');
    }

    public function linkUser(){
        return $this->hasMany(UserLinkGroup::class,"gid","id");
    }

    public function user(){
        return $this->hasOne(User::class, 'id', 'create_id')->field("id,username");
    }

belongsTo:属于

当前方法的模型对应的数据表,属于另一个模型。相当于多对一。

belongsTo('别的表模型名','本表外键名','本表关联表主键名',['模型别名定义'],'join类型');

    public function department(){
        return $this->belongsTo(Department::class,"department_id","id")->field('id,name');
    }

深入写法:

添加一些条件语句查询:

        $data = CategoryModel::with(['files' => function($q) use ($unVisibleFileIds){
            $q->where('id','not in', $unVisibleFileIds)->where('status','1')->where('pid',0);
        }])->where($map)->select();

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-12-14 16:15:41  更:2021-12-14 16:16:17 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/18 7:28:03-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码