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

表连接查询之两个left join与递归SQL

 一、如下SQL1

 SELECT i.*,su1.name as createName,su2.name as updateNameFROM information ileft join sys_user su1 on su1.id=i.create_idleft join sys_user su2 on su2.id=i.update_id

 二、分析

 1、SELECT i.*,su.name as createName,sua.name as updateName FROM information i:

查询结果为  information表的所有列(i.*),以及两个左连接的结果中的name字段。

 2、left join sys_user su1 on su1.id=i.create_id:

左连接,将information表中的每一行  与sys_user表中id   等于  information表中create_id的行  匹配。如果create_id在information表中没有对应的值,那么这个字段的值就是NULL。

3、left join sys_user su2 on su2.id=i.update_id:

左连接,将information表中的每一行与sys_user表中id等于information表中update_id的行匹配

结果集

(1,1,2,张三,李四),

(2,1,3,张三,王五),

(3,2,4,李四,小明)

三、如下SQL2

WITH RECURSIVE ParentHierarchy AS (SELECT id, user_id, parent_idFROM eWHERE user_id = #{userId}UNION ALLSELECT e.id, e.user_id, e.parent_idFROM  eINNER JOIN ParentHierarchy ph 
ON e.id = ph.parent_id)SELECT *FROM ParentHierarchyWHERE parent_id = 0;

1、WITH RECURSIVE ParentHierarchy AS (...):定义了一个递归的公用表 表达式,名为ParentHierarchy 。

2、SELECT id, user_id, parent_id FROM e WHERE user_id = #{userId}:递归的初始查询部分,即递归的基准条件,从表e中选择那些user_id字段等于指定userId的记录,这些记录就是层级结构的起始点。

3、UNION ALL:这个关键字用来将初始查询的结果和后续递归查询的结果合并在一起。(与union1不同,可能有重复记录)

4、SELECT e.id, e.user_id, e.parent_id FROM e INNER JOIN ParentHierarchy ph ON e.id = ph.parent_id:递归的主体部分,将表e与已经构建的ParentHierarchy进行内连接,匹配e表中的id和ParentHierarchy中的parent_id,从而得到下一级的层级数据。

5、SELECT * FROM ParentHierarchy WHERE parent_id = 0:最终的查询语句,它从递归构建的层级结构中选出所有parent_id为0的记录。

举例说明:表e

1、第一步

user_id=15

初始PH (6,3,15)

e表

inner join 它会返回两个表中字段匹配的行  ph.parent_id=e.id

结果集

(1,0,10)

2、第二步

选出所有parent_id为0的记录

结果

(1,0,10)

四、思考

什么时候此递归会返回null值?

http://www.lryc.cn/news/434923.html

相关文章:

  • 2024.9.10
  • 22_图论中的高级数据结构
  • axure判断
  • 【开源大模型生态7】华为的盘古大模型
  • SprinBoot+Vue远程教育网站的设计与实现
  • docker的基本操作
  • 理解 RabbitMQ:生产者、连接、通道、交换机、队列与消费者的消息流
  • 【截图服务 +打包】pkg打包 puppeteer
  • 深入理解Servlet的并发处理机制小波制图流程图
  • Ajax和XMLHttpRequest之间的关系
  • Linxu系统:kill命令
  • 解决缺少genconfig
  • 百易云资产管理运营系统 house.save.php SQL注入漏洞
  • 【安卓13 源码】Input子系统(3) - EventHub增加设备的流程
  • 基于JAVA+SpringBoot+Vue的网上商城系统的设计与实现
  • Mysql基础练习题 1729.求关注者的数量 (力扣)
  • 【鸿蒙HarmonyOS NEXT】页面和自定义组件生命周期
  • Node.js Express 框架
  • 生日贺卡录放音芯片,多段音频录音ic生产厂商,NVF04M-32minute
  • 电影《西施新传》首映礼,九月金秋全国正式公映
  • 【H2O2|全栈】关于CSS(1)CSS基础(一)
  • 动态规划算法之背包问题详细解读(附带Java代码解读)
  • Vue3+TypeScript二次封装axios
  • 华为 HCIP-Datacom H12-821 题库 (16)
  • 【论文分享精炼版】 sNPU: Trusted Execution Environments on Integrated NPUs
  • MyBatis 入门之动态 SQL
  • 软工大二学生待办事项:
  • MongoDB延迟查询
  • python如何获取html中的所有链接
  • 79-java static修饰的类能不能被继承