mysql cte递归_SQLSERVER中CTE语句结构及CTE递归查询

SQL SERVER中CTE语句结构及CTE递归查询 CTE语句结构 公用表表达式 (CTE) 可以认为是在单个 SELECT、INSERT、UPDATE、DELETE 或 CREATE VIEW 语句的执行范围内定义的临时结果集。CTE 与派生表类似,具体表现在不存储为对象,并且只在查询期间有效。与派生表的

SQL SERVER中CTE语句结构及CTE递归查询

CTE语句结构

公用表表达式 (CTE) 可以认为是在单个 SELECT、INSERT、UPDATE、DELETE 或 CREATE VIEW 语句的执行范围内定义的临时结果集。CTE 与派生表类似,具体表现在不存储为对象,并且只在查询期间有效。与派生表的不同之处在于,CTE 可自引用,还可在同一查询中引用多次。

使用上面的test4表为例:

WITH TEST_CTE

AS

(

select * from test4

)

此句创建了名为TEST_CTE的select * from test4的结果集。由于它不存储为对象,并且只在查询期间有效,所CTE和查询语句需要在一起执行:

WITH TEST_CTE

AS

(

select * from test4

)

select * from TEST_CTE

结果集跟select * from test4结果集机同。

下面是指定列的CTE使用:

WITH TEST_CTE(id)

AS

(

select id from test4

)

定义中的列需要与语句里面的列对应,,见红色字体。

CTE可用于创建递归查询。

创建测试表并插入数据:

create table test5

(

id int,

name varchar(50),

parentid int

)

insert into test5(id,name,parentid)

select 1,'父类1',0

union all

select 2,'父类2',0

union all

select 3,'父类3',0

union all

select 11,'子类11',1

union all

select 12,'子类12',1

union all

select 111,'子子类111',11

union all

select 22,'子类22',2

union all

select 222,'子子类222',22

结果:

id name parentid

1 父类1 0

2 父类2 0

3 父类3 0

11 子类11 1

12 子类12 1

111 子子类111 11

22 子类22 2

222 子子类222 22

使用CTE创建递归查询,获取父类1及所有其子类及子类的子类...:

with Test_Recursion(id,name,parentid,[level])

AS

(

select id,name,parentid,0 from test5 where id =1--没有引用CTE自身必须放在第一个递归行之上

union all--没有引用CTE自身的语句和第一个递归行之间必须用UNION ALL

select a.id,a.name,a.parentid,b.[level]+1 from test5 as a join Test_Recursion as b on a.parentid=b.id--递归行

)

select * from Test_Recursion

结果:

id name parentid level

1 父类1 0 0

11 子类11 1 1

12 子类12 1 1

111 子子类111 11 2

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值