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

sql递归查询

一、postgresql

递归sql

with recursive p as(select t1.* from t_org_test t1 where t1.id=2union allselect t2.*from t_org_test t2 join p on t2.parent_id=p.id)
select id,name,parent_id from p;

 

sql中with xxxx as () 是对一个查询子句做别名,同时数据库会对该子句生成临时表;
with recursive 则是一个递归的查询子句,他会把查询出来的结果再次代入到查询子句中继续查询
p为自定义临时表名,最后一句select后跟的字段必须小于等于t1和t2中字段。
第二句where后面跟的是起始数据,第四句后面可以加where条件来判断终止条件
向上递归把t2.parent_id=p.id改为t2.id=p.parent_id
二、orcle

 

三、mysql

delimiter $$ 
drop function if exists get_child_list$$ 
create function get_child_list(in_id varchar(10)) returns varchar(1000) 
begin declare ids varchar(1000) default ''; declare tempids varchar(1000); set tempids = in_id; while tempids is not null do set ids = CONCAT_WS(',',ids,tempids); select GROUP_CONCAT(id) into tempids from t_org_test where FIND_IN_SET(parent_id,tempids)>0;  end while; return ids; 
end  
$$ 
delimiter ; 

 

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

相关文章:

  • 常见前端面试之VUE面试题汇总三
  • Three.js 实现模型材质分解,拆分,拆解效果
  • 《JVM修仙之路》初入JVM世界
  • 苍穹外卖 day1 搭建成功环境
  • 智能主体按照功能划分
  • python中的matplotlib画折线图(数据分析与可视化)
  • 大数据数据仓库
  • Java“牵手“速卖通商品详情页面数据获取方法,速卖通API实现批量商品数据抓取示例
  • 【Git】代码误推送还原(真实项目环境,非纸上谈兵)
  • CPU 飙升?这3大场景助你精准定位
  • 6、Spring_Junit与JdbcTemplate整合
  • Redis是如何保证高可用的?
  • 精益求精:通付盾安卓应用加固升级,为移动安全保驾护航!
  • javaweb01-html、css基础
  • 牛客复盘] 2023河南萌新联赛第(七)场:信息工程大学 B\I 20230823
  • 使用PyMuPDF添加PDF水印
  • window如何实时刷新日志文件
  • 动态代理的两个使用方式(手动实现+SpringAOP实现)-Demo
  • 面试话术(MQ+mybatis+nginx+redis+ssm+mysql+linux)
  • JSON的理解
  • 面试热题(二叉树的最大路径)
  • C#设计模式之--六大原则 开闭原则
  • 编写Dockerfile制作自己的镜像并推送到私有仓库
  • 华为OD-分积木/分苹果
  • Mysql的引擎有哪些?支持事物么?DB储存引擎有哪些?
  • 【懒加载】js实现懒加载、vue实现图片懒加载指令
  • 微信小程序教学系列(7)
  • Android 9.0 kenel和frameworks中修改ram运行内存的功能实现
  • PHP实践:获取网络上图片的长宽以及图片类型
  • 使用 DPO 微调 Llama 2