• 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 用在属于批处理的一部分的语句中,那么在它之前的语句必须以分号结尾。

  • 相关阅读:
    使用批处理发布 QT 的程序
    转载:单一小农经济结构是我国长期动乱贫穷的病根
    JavaScript 盖尔-沙普利算法
    c# 自定义控件之 ComboBox
    c# PID算法入门
    c# 盖尔-沙普利算法的改进
    c# 陈景润 15 子问题
    c# 排序算法可视化
    c# 线程,同步,锁
    c# 小票打印
  • 原文地址:https://www.cnblogs.com/llcdbk/p/3894635.html
Copyright © 2020-2023  润新知