sql 使用with as 語句報 “Only `SELECT` statements are allowed against this database”錯誤


with as 語句又叫CTE,公用表表達式,可以將一個sql語句的結果用一個 變量名來表示,方便后續多次引用。可以用來高性能地簡化嵌套sql

參考:https://www.cnblogs.com/fygh/archive/2012/04/25/2160266.html

 

在使用CTE時應注意如下幾點:

1. CTE后面必須直接跟使用CTE的SQL語句(如select、insert、update等),否則,CTE將失效。如下面的SQL語句將無法正
常使用CTE:

復制代碼
with 
cr as
(
select CountryRegionCode from person.CountryRegion where Name like 'C%'
)
select * from person.CountryRegion -- 應將這條SQL語句去掉
-- 使用CTE的SQL語句應緊跟在相關的CTE后面--
select * from person.StateProvince where CountryRegionCode in (select * from cr)
復制代碼

 


2. CTE后面也可以跟其他的CTE,但只能使用一個with,多個CTE中間用逗號(,)分隔,如下面的SQL語句所示:

復制代碼
with 
cte1 as
(
select * from table1 where name like 'abc%'
),
cte2 as
(
select * from table2 where id > 20
),
cte3 as
(
select * from table3 where price < 100
)
select a.* from cte1 a, cte2 b, cte3 c where a.id = b.id and a.id = c.id
復制代碼

 


3. 如果CTE的表達式名稱與某個數據表或視圖重名,則緊跟在該CTE后面的SQL語句使用的仍然是CTE,當然,后面的SQL語句
使用的就是數據表或視圖了,如下面的SQL語句所示:

復制代碼
--  table1是一個實際存在的表
with
table1 as
(
select * from persons where age < 30
)
select * from table1 -- 使用了名為table1的公共表表達式
select * from table1 -- 使用了名為table1的數據表
復制代碼

 


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)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM