当前位置: 首页 > 工具软件 > asSQL > 使用案例 >

sql server with temp as用法

邢飞昂
2023-12-01

WITH temp AS (
SELECT D.DocumentId,PR, EBELN FROM Document AS D 
LEFT JOIN Contract C ON D.DocumentId = C.DocumentId
LEFT JOIN PO_Item P ON D.PR = P.BANFN
WHERE D.ProcessLinkId=8 AND PR IS NOT NULL),
TEMP1 AS(
 SELECT D.DocumentId,D.CompanyName '公司',FORMAT(ApplicationDate,'yyyy') '年度',ProjectName '项目名称',BaseCurrencyProjectBudget '金额',CurrencyCode '币种' FROM Document AS D
 LEFT JOIN ProjectService AS PS ON D.DocumentId=PS.DocumentId
 WHERE D.ProcessLinkId=2
),
TEMP2 AS(
SELECT D.DocumentId ,D.CompanyName '公司',FORMAT(ApplicationDate,'yyyy') '年度',ProjectName '项目名称',BaseCurrencyProjectBudget '金额',T.EBELN 'PO',CurrencyCode '币种' FROM ProcessLinkRecord P
LEFT JOIN temp T ON P.RecordId=T.DocumentId
LEFT JOIN ProjectService S ON S.DocumentId = P.PreviousRecordId
LEFT JOIN Document D ON S.DocumentId = D.DocumentId
WHERE P.PreviousProcessLinkId=2 AND P.ProcessLinkId=8)
SELECT T1.公司,T1.年度,T1.项目名称,T1.金额,T2.PO,T1.币种 FROM TEMP1 T1
LEFT JOIN TEMP2 T2 ON T1.DocumentId = T2.DocumentId

1. temp后面必须直接跟使用temp的SQL语句(如select、insert、update等),否则,temp将失效。如下面的SQL语句将无法正常使用temp:

WITH temp AS (
SELECT D.DocumentId,PR, EBELN FROM Document AS D 
LEFT JOIN Contract C ON D.DocumentId = C.DocumentId
LEFT JOIN PO_Item P ON D.PR = P.BANFN
WHERE D.ProcessLinkId=8 AND PR IS NOT NULL)

SELECT *FROM DOCUMENT 

SELECT *FROM temp ----temp失效

2. temp后面也可以跟其他的TEMP1,但只能使用一个with,多个temp中间用逗号(,)分隔,如上面的SQL语句所示

3. 如果DOCUMENT的表达式名称与某个数据表或视图重名,则紧跟在该DOCUMENT后面的SQL语句使用的仍然是DOCUMENT,当然,后面的SQL语句使用的就是数据表或视图了,如下面的SQL语句所示:
--  DOCUMENT是一个实际存在的表
WITH
DOCUMENT AS
(
   SELECT *FROM DOCUMENT
)
select * from DOCUMENT--  使用了名为DOCUMENT的公共表表达式
select * from DOCUMENT--  使用了名为DOCUMENT的数据表

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语句外,还可以进行递归调用
--------------------- 

 

 类似资料: