共計 1286 個字符,預計需要花費 4 分鐘才能閱讀完成。
行業資訊
數據庫
SQL Server 中 set quoted_identifier 的使用方法
自動寫代碼機器人,免費開通
丸趣 TV 小編給大家分享一下 SQL Server 中 set quoted_identifier 的使用方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
SQL Server 在存儲過程中經常會有
SET QUOTED_IDENTIFIER on
SET QUOTED_IDENTIFIER off
如果 SET QUOTED_IDENTIFIER on 時,在創建一個表時,如果這個表的表名,剛好用到了 sqlserver 的關鍵字,如下面的情況
create table distinct(
id int not null constraint pk_1 primary key,
value varchar(255),
flag int
)
上面的語句運行是會出錯的,不管 SET QUOTED_IDENTIFIER 為 on 還是 off,會提示 在關鍵字 distinct 附近有語法錯誤。
SQL Server 中 SET QUOTED_IDENTIFIER 的用法
那是因為 distinct 是 sqlserver 的標識符,如果想以 distinct 為表時,在 QUOTED_IDENTIFIER 為 off 的情況下,是不能創建表名為 distinct 的表的,因為在 QUOTED_IDENTIFIER 為 off 情況下,sqlserver 的標識符是不允許加引號的,所以在 SET QUOTED_IDENTIFIER off 的情況下,不管 distinct 加引號或不加引號或加雙引號都是不可以的。
但是在 SET QUOTED_IDENTIFIER on 的情況下是可以把 sqlserver 的標識符加上雙引號來創建以 sqlserver 標識符為表名的表,但是加單引號也是不可以的。
create table distinct (
id int not null constraint pk_1 primary key,
value varchar(255),
flag int
)
可以運行
create table ‘distinct’(
id int not null constraint pk_1 primary key,
value varchar(255),
flag int
)
不可以運行
當 SET QUOTED_IDENTIFIER 為 ON 時,標識符 / 數據庫內關鍵字可以由雙引號括著。當 SET QUOTED_IDENTIFIER 為 OFF 時,標識符不可加引號,加了引號也沒有用,且必須符合所有 Transact-SQL 標識符規則。
1SELECT SESSIONPROPERTY(QUOTED_IDENTIFIER) quotedidentifier
默認為 on
以上是“SQL Server 中 set quoted_identifier 的使用方法”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注丸趣 TV 行業資訊頻道!
向 AI 問一下細節