问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

SQL中使用WITH 语句的查询

发布网友 发布时间:2022-04-30 16:23

我来回答

2个回答

热心网友 时间:2022-04-09 00:46

sql with as 用法(适用sqlserver,好像oracle也适用)

Server 2005中提供了公用表表达式(CTE),使用CTE,可以使SQL语句的可维护性,同时,CTE要比表变量的效率高得多。

下面是CTE的语法:
[ WITH <common_table_expression> [ ,n ] ]
< common_table_expression>::=
expression_name [ ( column_name [ ,n ] ) ]
AS
( CTE_query_definition )

现在使用CTE来解决上面的问题,SQL语句如下:

with
cr as
(
select CountryRegionCode from person.CountryRegion where Name like 'C%'
)

select * from person.StateProvince where CountryRegionCode in (select * from cr)

其中cr是一个公用表表达式,该表达式在使用上与表变量类似,只是SQL Server 2005在处理公用表表达式的方式上有所不同。
在使用CTE时应注意如下几点:
1. CTE后面必须直接跟使用CTE的SQL语句(如select、insert、update等),否则,CTE将失效。如下面的SQL语句将无法正常使用CTE:

with
cr as
(
select CountryRegionCode from person.CountryRegion where Name like 'C%'
)
select * from person.CountryRegion -- 应将这条SQL语句去掉
-- 使用CTE的SQL语句应紧跟在相关的CTE后面 --
select * from person.StateProvince where CountryRegionCode in (select * from cr)

2. CTE后面也可以跟其他的CTE,但只能使用一个with,多个CTE中间用逗号(,)分隔,如下面的SQL语句所示:
with
cte1 as
(
select * from table1 where name like 'abc%'
),
cte2 as
(
select * from table2 where id > 20
),
cte3 as
(
select * from table3 where price < 100
)
select a.* from cte1 a, cte2 b, cte3 c where a.id = b.id and a.id = c.id

3. 如果CTE的表达式名称与某个数据表或视图重名,则紧跟在该CTE后面的SQL语句使用的仍然是CTE,当然,后面的SQL语句使用的就是数据表或视图了,如下面的SQL语句所示:
-- table1是一个实际存在的表
with
table1 as
(
select * from persons where age < 30
)
select * from table1 -- 使用了名为table1的公共表表达式
select * from table1 -- 使用了名为table1的数据表

4. CTE 可以引用自身,也可以引用在同一 WITH 子句中预先定义的 CTE。不允许前向引用。

5. 不能在 CTE_query_definition 中使用以下子句:
(1)COMPUTE 或 COMPUTE BY
(2)ORDER BY(除非指定了 TOP 子句)
(3)INTO
(4)带有查询提示的 OPTION 子句
(5)FOR XML
(6)FOR BROWSE

6. 如果将 CTE 用在属于批处理的一部分的语句中,那么在它之前的语句必须以分号结尾,如下面的SQL所示:
declare @s nvarchar(3)
set @s = 'C%'
; -- 必须加分号
with
t_tree as
(
select CountryRegionCode from person.CountryRegion where Name like @s
)
select * from person.StateProvince where CountryRegionCode in (select * from t_tree)

7、CTE除了可以简化嵌套SQL语句外,还可以进行递归调用

热心网友 时间:2022-04-09 02:04

楼主要先明白公用表表达式的用法,才不会出错,应该这样:
-------------CTE公用表表达式的使用方法
;WITH
Total_balance AS(
SELECT branch_name,SUM(balance) balance
FROM account
GROUP BY branch_name
)--每个CTE后面必须紧跟一条SELECT或UPDATE或DELETE得DML语句
SELECT * FROM Total_balance
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
悲观的意思是什么悲观是什么意思 ...坐立不安的。还总想挠挠手呀、胳膊什么的。这是怎么回事啊?是一种... ...胳膊肘麻,有时会麻到感觉大拇指根部疼,食指也有点... ...入睡感觉左胳膊从手腕到肩膀酥溜溜的酸,睁开眼又好了,什么原因... 胳膊上麻溜溜的 像是有小疙瘩 还很痒 有点硬 少量蔗糖,食盐,食油,食醋分别倒入一定量水中,并用筷子不断搅拌,观察... 将食盐 蔗糖 泥土 植物油与水混合 英文会计的provision对应中文会计的哪个词啊? 双人旁一个直一个心念什么,什么意思 白瓷有隙是成语吗 梦见自己的门市里有许多血 在Sql Server 2005中,如何写存储过程,得到数据库中各个表的记录数? 梦见家里的大门开着,地上流出一滩血,一路流出血,我就拿布擦血,然后我表... 梦见街门外边有白色官财流出三点红血是怎么回事? ...sql写法:树节点放一个表中,怎么用一条语句查询一个节点及对应的所有... 梦见自己家大门外有许多血还有许多人围观好不好 一条sql语句顺序查询出父类的所有子类 如下图:用的是sql Server... 梦见家门前面有很多血 梦见门不打自开,在房中看见很多血 sql server 递归汇总 按指定层级汇总 梦见一起来开门门外全是血 梦见在家杀人外门上都是血这是什么意思? Sql Server的递归查询怎么写?不能使用存储过程 梦见我儿子把死人头抱到家里来,门上还有血, 求助SQL中CTE递归的问题。。。谢谢! 梦见把血泼在别人家门上了 大然的自然动物作文250485588字 Delphi 7 中ado组件怎么支持sql server 2005版本的cte 递归查询... 梦见受伤了 血喷到了白色的门上 我还用破布擦 一会就都擦掉了 梦见老家大门往地上流血 sql2005 根据子ID递归查询所有父ID,如下,问:dbo怎么才能否去掉?_百度... 按客户ID,取查询结果集的最大值, SQL2005 什么软件可以帮助我在虎牙更好的直播? 如何实现文档快速合并? 如何快速合并word文档 普特快速电热水器多少钱、型号p丅3-A、B、C、D、F、H系列 历史上有没有记载,伊姆霍特普有没有兄弟姐妹?以及伊姆霍特普和左塞王的生猝年? 格列佛游记中 飞岛国又称作() A,勒皮他 B,布罗丁奈格 C,日本 D,利立... 印度发源于喜马拉雅山南坡,注入孟加拉湾的火河是(  )A.印度河B.恒河C.雅鲁藏布江D.布拉马普特拉 关于下列河流出国后改名,正确的是(  ) A.①-萨尔温江 B.②-布拉马普特拉河 C.③-湄公河 根据考古发现,以下哪一项是阿蒙霍特普四世的爱好 飞鸟国又称作什么 A.勒皮他 B.布罗丁奈格 C.日本 D.利立普特 青岛特普电子有限公司怎么样? f450无人机遥控器怎么对频 用电脑画图软件调照片尺寸,需要输入水平和垂直百分比数是多少? Ω怎么读怎么打字出来 为什么我的前程无忧登录不了呢?我已经注册过的,换了一台手机就登录不了了 拼音加加输入法怎样打出希腊字母? 前程无忧怎么登陆;它的网址是多少 我怎么上前程无忧网总上不去,说我网络有问题,上其他网页也可以啊