SQLSERVER中CTE语句结构及CTE递归查询

  次阅读 作者:智能小宝 来源:互联网 2016-02-17 09:45 我要评论(0)

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 * fromtest4的结果集。由于它不存储为对象,并且只在查询期间有效,所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自身必须放在第一个递归行之上

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...