zoukankan      html  css  js  c++  java
  • CTE初识

    微软从SQl2005起引入了CTE(Common Table Expression)以强化T-SQL。这是一个类似于非持久视图的好东西。

    正常的SQL语句:

    select * from person.StateProvince where CountryRegionCode in 
    (select CountryRegionCode from person.CountryRegion where Name like 'C%') 

    CTE写循环递归的语句:

    with 
    cr as 
    ( 
    select CountryRegionCode from person.CountryRegion where Name like 'C%'   --这是条件
    ) 
    select * from person.StateProvince where CountryRegionCode in (select * from cr) 

    在使用CTE时应注意如下几点: 
    1. CTE后面必须直接跟使用CTE的SQL语句(如select、insert、update等),否则,CTE将失效。 
    2. CTE后面也可以跟其他的CTE,但只能使用一个with,多个CTE中间用逗号(,)分隔。 
    3. 如果CTE的表达式名称与某个数据表或视图重名,则紧跟在该CTE后面的SQL语句使用的仍然是CTE,当然,后面的SQL语句使用的就是数据表或视图了。 
    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 用在属于批处理的一部分的语句中,那么在它之前的语句必须以分号结尾。

  • 相关阅读:
    二重循环
    汇编中的大小写转换
    编译出错:must be index or base register
    [bx]和loop指令
    poj1012约瑟夫
    fenshijin
    poj3050
    抹蛋糕
    poj1190
    uuu
  • 原文地址:https://www.cnblogs.com/llcdbk/p/3894635.html
Copyright © 2011-2022 走看看