欢迎来到IDC91站长网!
解决服务器各种技术问题,加微信uecomzsr

MySQL

当前位置: IDC91 > 数据库 > MySQL

MySql8 WITH RECURSIVE递归查询父子集的方法

时间:2022-05-30 13:59:28|栏目:MySQL|点击:

背景

开发过程中遇到类似评论的功能是,需要时用查询所有评论的子集。不同数据库中实现方式也不同,本文使用Mysql数据库,版本为8.0

  • Oracle数据库中可使用START [Param] CONNECT BY PRIOR
  • Mysql 中需要使用 WITH RECURSIVE

需求

找到name为张三的孩子和孙子,pid为当前记录的父id,如张三儿子的pid为张三的id,以此类推。

在这里插入图片描述

引入

计算1到100的累加的结果。
WITH RECURSIVE t(n) AS ( //t为我们结果表,n为字段,可以只指定表明不指定字段
  VALUES (1) //递归的开始,此时可理解为t表字段n只有一条记录 1
 UNION ALL
  SELECT n+1 FROM t WHERE n < 100   
  /*这里产生的结果为 2 ,此时t表的字段n有两条记录分别为1,2
  *				 3
  *         ...
  *         100
  */													  
)
SELECT sum(n) FROM t; //对字段n求和

上一篇:详解MySQL的sql_mode查询与设置

栏    目:MySQL

下一篇:解决seata不能使用mysql8版本的问题方法

本文标题:MySql8 WITH RECURSIVE递归查询父子集的方法

本文地址:https://idc91.com/shujuku/4110.html

广告投放 | 联系我们 | 免责申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

Copyright © 2023 IDC91.COM 版权所有晋ICP备17006296号