公用表表达式CTE

  公用表表达式CTE表面上和派生表非常相似,看起来只是语义上的区别。但和派生表比较起来,CTE具有几个优势:第一,如果须要在一个CTE中引用另一个CTE,不需要像派生表那样嵌套,相反,只要简单地在同一个WITH子句中定义多个CTE,并用逗号把它们分隔开。每个CTE可以引用在它前面定义的所有CTE。而外部查询可以引用所有CTE。

  下面是一个公用表表达式CTE的示例。

USE TSQLFundamentals2008;
GO

-- 公用表表达式CTE
-- 一个简单的公用表表达式的例子
WITH USACusts AS
(
    SELECT custid,companyname FROM Sales.Customers
    WHERE country= N‘USA‘
)
SELECT * FROM USACusts;

-- 分配列别名
WITH C AS
(
    SELECT YEAR(orderdate) AS orderyear,custid FROM Sales.Orders
)
SELECT orderyear, COUNT(DISTINCT custid) FROM C
GROUP BY orderyear;

-- 使用参数
DECLARE @empid AS INT=3;

WITH C AS
(
    SELECT YEAR(orderdate) AS orderyear,custid FROM Sales.Orders
    WHERE empid= @empid
)
SELECT orderyear, COUNT(DISTINCT custid)
FROM C
GROUP BY orderyear;

-- 定义多个CTE
WITH C1 AS
(
    SELECT YEAR(orderdate) AS orderyear, custid FROM Sales.Orders
),
C2 AS
(
    SELECT orderyear,COUNT(DISTINCT custid) AS numcusts FROM C1
    GROUP BY orderyear
)
SELECT orderyear,numcusts FROM C2
WHERE numcusts>70;

-- CTE的多引用
WITH YearlyCount AS
(
    SELECT YEAR(orderdate) AS orderyear, COUNT(DISTINCT custid) AS numcusts FROM Sales.Orders
    GROUP BY YEAR(orderdate)
)
SELECT Cur.orderyear, Cur.numcusts AS curnumcusts,Prv.numcusts AS prvnumcusts,Cur.numcusts-Prv.numcusts AS growth
FROM YearlyCount AS Cur
LEFT JOIN YearlyCount AS Prv ON Cur.orderyear = Prv.orderyear+1;
时间: 2024-10-06 03:25:59

公用表表达式CTE的相关文章

T-SQL查询进阶--详解公用表表达式(CTE)

简介 对于SELECT查询语句来说,通常情况下,为了使T-SQL代码更加简洁和可读,在一个查询中引用另外的结果集都是通过视图而不是子查询来进行分解的.但是,视图是作为系统对象存在数据库中,那对于结果集仅仅需要在存储过程或是用户自定义函数中使用一次的时候,使用视图就显得有些奢侈了. 公用表表达式(Common Table Expression)是SQL SERVER 2005版本之后引入的一个特性.CTE可以看作是一个临时的结果集,可以在接下来的一个SELECT,INSERT,UPDATE,DEL

T-SQL 公用表表达式(CTE)

公用表表达式(CTE) 在编写T-SQL代码时,往往需要临时存储某些结果集.前面我们已经广泛使用和介绍了两种临时存储结果集的方法:临时表和表变量.除此之外,还可以使用公用表表达式的方法.公用表表达式(Common Table Expression)是SQL Server2005版本的引入的一个特性.CTE可以看组是一个临时的结果集,可以再接下来来的一个SELECT,INSERT,UPDATE,DELETE,MERGE语句中多次引用.使用公用表达式CTE可以让语句更加清晰简练.与公用表达式作用类似

详解公用表表达式(CTE)

简介 对于SELECT查询语句来说,通常情况下,为了使T-SQL代码更加简洁和可读,在一个查询中引用另外的结果集都是通过视图而不是子查询来进行分解的.但是,视图是作为系统对象存在数据库中,那对于结果集仅仅需要在存储过程或是用户自定义函数中使用一次的时候,使用视图就显得有些奢侈了. 公用表表达式(Common Table Expression)是SQL SERVER 2005版本之后引入的一个特性.CTE可以看作是一个临时的结果集,可以在接下来的一个SELECT,INSERT,UPDATE,DEL

SQL Server 公用表表达式(CTE)实现递归

公用表表达式简介: 公用表表达式 (CTE) 可以认为是在单个 SELECT.INSERT.UPDATE.DELETE 或 CREATE VIEW 语句的执行范围内定义的临时结果集.CTE 与派生表类似,具体表现在不存储为对象,并且只在查询期间有效.与派生表的不同之处在于,公用表表达式 (CTE) 具有一个重要的优点,那就是能够引用其自身,从而创建递归 CTE.递归 CTE 是一个重复执行初始 CTE 以返回数据子集直到获取完整结果集的公用表表达式. 下面先创建一个表,并插入一些数据: crea

mysql8 公用表表达式CTE的使用

公用表表达式CTE就是命名的临时结果集,作用范围是当前语句. 说白点你可以理解成一个可以复用的子查询,当然跟子查询还是有点区别的,CTE可以引用其他CTE,但子查询不能引用其他子查询. 一.cte的语法格式: with_clause: WITH [RECURSIVE] cte_name [(col_name [, col_name] ...)] AS (subquery) [, cte_name [(col_name [, col_name] ...)] AS (subquery)] ... 二

使用公用表表达式(CTE)

本文来自:http://blog.csdn.net/songjie521/article/details/3321030 通用表表达式(CTEs)是SQL Server 2005的一项新功能.它们类似于alias(如在SELECT T1.* FROM MyTable T1中),不过功能更为强大.本质上,CTE是一个临时结果集,它仅仅存在于它发生的语句中.您可以在SELECT.INSERT.DELETE. UPDATE或CTEATE VIEW语句中建立一个CTE.CTE类似于派生表,但拥有几项优点

公用表表达式(CTE)

下面看在CTE中分配列别名的两种格式:内联格式和外部格式. 内联格式: 1 WITH C AS 2 ( 3 SELECT YEAR(orderdate) AS orderyear, custid 4 FROM Sales.Orders 5 ) 6 SELECT orderyear, COUNT(DISTINCT custid) AS numcusts 7 FROM C 8 GROUP BY orderyear; 外部格式: 1 WITH C(orderyear, custid) AS 2 ( 3

关于SQL中CTE(公用表表达式)(Common Table Expression)的总结

WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到 一.WITH AS的含义 WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到.有的时候,是为了让SQL语句的可读性更高些, 也有可能是在UNION ALL的不同部分,作为提供数据的部分. 特别对于UNION ALL比较有用.因为UNION

T-SQL 之 公用表表达式(CTE)

在编写T-SQL代码时,往往需要临时存储某些结果集.在CTE之前常用的两种临时存储结果集为:临时表和表变量.除此之外,还可以使用公用表表达式的方法. 公用表表达式(Common Table Expression)是SQL Server2005版本的引入的一个特性.CTE可以看作是一个临时的结果集,可以再接下来来的一个SELECT,INSERT,UPDATE,DELETE,MERGE 语句中多次引用.使用公用表达式CTE可以让语句更加清晰简练. 一.三种方式的对比 (一).临时表:需要在临时数据库