数据库 
首页 > 数据库 > 浏览文章

MSSQL中递归SQL查询语句实例说明-

(编辑:jimmy 日期: 2024/11/25 浏览:3 次 )

一张表(ColumnTable)的结构如下图所示

MSSQL中递归SQL查询语句实例说明-

当前需要实现的功能:通过Number的值为67来获取当前的节点ID、父节点ID

递归实现SQL语句:
复制代码 代码如下:
with znieyu as
(
select c.Id,c.FatherId,0 as lv1 from ColumnTable c where c.Number=67
union all
select c.Id,c.FatherId,lv1-1 from znieyu z
inner join ColumnTable c
on z.FatherId=c.Id
)
select znieyu.Id ,znieyu.FatherId,znieyu.lv1 as lv from znieyu

实现的效果:

MSSQL中递归SQL查询语句实例说明-

满足条件67ID为6的递归-->6-->2(LV0)-->1(LV-1)-->0(LV-2)
满足条件67ID为8的递归-->8-->5(LV0)-->2(LV-1)-->1(LV-2)-->0(LV-3)
 很简单的一个SQL递归,记录下来...

上一篇:SQL Server Bulk Insert 只需要部分字段时的方法
下一篇:SQL 判断给定日期值(或时间段)所在星期的星期一和星期天的日期
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap