中易网

sqlserver with 语法

答案:2  悬赏:0  
解决时间 2021-01-18 02:12
  • 提问者网友:呐年旧曙光
  • 2021-01-17 14:51
sqlserver with 语法
最佳答案
  • 二级知识专家网友:骨子里都是戏
  • 2021-01-17 16:25
一.sqlserver with as的含义
  WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到。有的时候,是为了让SQL语句的可读性更高些,也有可能是在UNIOn ALL的不同部分,作为提供数据的部分。
  特别对于UNIOn ALL比较有用。因为UNIOn ALL的每个部分可能相同,但是如果每个部分都去执行一遍的话,则成本太高,所以可以使用WITH AS短语,则只要执行一遍即可。如果WITH AS短语所定义的表名被调用两次以上,则优化器会自动将WITH AS短语所获取的数据放入一个TEMP表里,如果只是被调用一次,则不会。而提示materialize则是强制将WITH AS短语里的数据放入一个全局临时表里。很多查询通过这种方法都可以提高速度。
二.使用方法
  先看下面一个嵌套的查询语句:
  select * from person.StateProvince where CountryRegionCode in
  (select CountryRegionCode from person.CountryRegion where Name like 'C%')
  declare @t table(CountryRegionCode nvarchar(3))
  insert into @t(CountryRegionCode) (select CountryRegionCode from person.CountryRegion where Name like 'C%')
  select * from person.StateProvince where CountryRegionCode
  in (select * from @t)
全部回答
  • 1楼网友:佘樂
  • 2021-01-17 17:10
在with前面加个分号(;)
;with
cte1 as ...
如果不加分号,单独执行应该没有问题。
如果是作为批处理的一部分,那必须加分号;
补充:
CTE是SQL2005新增的功能,SQL2000不支持CTE。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息!
大家都在看
推荐信息