当前位置: 首页 > news >正文

Laravel关联模型查询

一,多表关联

文章表articles 和user_id,category_id关联

//with()方法是渴求式加载,缓解了1+N的查询问题,仅需1+1次查询就能解决问题,可以提升查询速度。with部分没有就以null输出,所以可以理解为  多表  left join 查询
//has()和whereHas() 是基于关联关系去过滤模型的查询结果,如果关联模型不符合条件那整体就没有数据。所以可以理解为多表  inner join 查询。
  • 模型关系
public function user(){return $this->belongsTo('App\Models\User','user_id','id');
}//表2public function category(){return $this->belongsTo('App\Models\Category','category_id','id');}
  • 控制器
//输出文章表中所有文章数据,如果符合用户id=1,分类name=科技 就输出关联的信息,没有就是null,类似left join 查询
$list = Article::with(['user'=>function($query){$query->where('id', '=', '1');},'category'=>function($query){$query->where('name', '=', '科技');},'模型定义的方法名'=>function($query){$query->where('name', '=', '科技');}
])
->where('status',1)
->get();
//输出文章表中符合条件的文章,需要满足用户id=1,分类name=科技 的条件,类似 inner join
//这里要注意,whereHas和has只做筛选,并不返回关系user和category中的数据,但是 with 是返回的。所以,当要返回关系数据时,两者要结合使用。
$list = Article::whereHas('user',function($query){$query->where('id', '=', '1');
})
->whereHas('category',function($query){$query->where('name', '=', '科技');
})
//这里的with 其实不用再写条件也行,因为前面的whereHas 已经限定了条件了
->with(['user'=>function($query){$query->where('id', '=', '1');},'category'=>function($query){$query->where('name', '=', '科技');}
])
->where('status',1)
->get();

实际使用

//$request->has() 判断参数是否存在,$request->filled() 判断参数存在且不为空
$id = $request->get('id');
$list = Article::whereHas('user',function($query) use ($id){if(!empty($id)){$query->where('id', '=', $id);}})
->whereHas('category',function($query){$query->where('name', '=', '科技');
})
//这里的with 其实不用再写条件也行,因为前面的whereHas 已经限定了条件了
->with(['user'=>function($query){$query->where('id', '=', '1');},'category'=>function($query){$query->where('name', '=', '科技');}
])
->where('status',1)
->get();

二,多表多层级嵌套关联查询

一个company有多个store,一个store有多个goods

$limit = $request->limit ?? 10;
$query = Goods::query()->where(['status' => 1]);
// 如果存在请求的公司,获取请求公司所有商家的每款产品
if ($request->company_ids){$companyIdsArr = explode(',', $request->company_ids);$query->whereHas('business', function ($query) use($companyIdsArr){$query->whereHas('commpany', function ($query) use($companyIdsArr){$query->whereIn('id', $companyIdsArr);});});
}
$list = $query->orderBy('id', 'desc')->paginate($limit)

输出goods列表包含所属的商家和商家所属的公司

$builder = Goods::where('status',1);
if($request->filled('type')){$builder->where('type',$request->type);
}
//两种都可以
//$builder->with(['business.company'])->get();
$list = $builder->with(['business'=>function($query){$query->with('company');
}])->get(); 
http://www.lryc.cn/news/497387.html

相关文章:

  • Clickhouse 数据类型
  • 物联网智能项目如何实现设备高效互联与数据处理?
  • 【云服务器】搭建博客服务
  • 如何抽象策略模式
  • BERT模型的输出格式探究以及提取出BERT 模型的CLS表示,last_hidden_state[:, 0, :]用于提取每个句子的CLS向量表示
  • node.js实现分页,jwt鉴权机制,token,cookie和session的区别
  • 34 基于单片机的指纹打卡系统
  • 【Linux】用户操作命令
  • Y20030018基于Java+Springboot+mysql+jsp+layui的家政服务系统的设计与实现 源代码 文档
  • windows部署PaddleSpeech详细教程
  • 线程条件变量 生产者消费者模型 Linux环境 C语言实现
  • C++ packaged_task
  • 【联表查询】.NET开源 ORM 框架 SqlSugar 系列
  • 嵌入式C编程:宏定义与typedef的深入对比与应用
  • 高级java每日一道面试题-2024年12月03日-JVM篇-什么是Stop The World? 什么是OopMap? 什么是安全点?
  • 【openGauss︱PostgreSQL】openGauss或PostgreSQL查表、索引、序列、权限、函数
  • Dataset用load_dataset读图片和对应的caption的一个坑
  • 【信息系统项目管理师】第7章:项目立项管理 考点梳理
  • 知识库、提示词对大语言模型的影响测试
  • vistat-监控和分析网络状态
  • EasyAnimateV5 视频生成大模型原理详解与模型使用
  • 水稻和拟南芥生命周期中单碱基分辨率的m6A定量分析-文献精读88
  • 学习threejs,使用canvas更新纹理
  • 【笔记2-3】ESP32 bug:PSRAM chip not found or not supported 没有外部PSRAM问题解决
  • 大数据hadoop、spark、flink、kafka发展的过程
  • 设计模式-理论基础
  • 猎板 PCB特殊工艺:铸就电子行业核心竞争力新高度
  • 用于目标检测的集中式特征金字塔
  • 大舍传媒-关于海外媒体宣发的探讨
  • Python从入门到入狱