SQL點滴6—“微軟不認識閏年2月29日”&字符"N"的作用
http://www.cnbeta.com/articles/50580.htm這個網頁新聞中報告許多微軟軟件不能識別閏年的2月29號 ,其中就包含SQL Server 2008,本人就在自己的SQL Server 2008中寫了幾個語句試驗,這幾個語句顯示能得到2月29號這一天,不知道照這則新聞所說在這一天安裝軟件會不會導致錯誤。
select DATEADD(DD,1,'28/Feb/2008') 輸出:2008-02-29 00:00:00.000 select DATEADD(DD,1,'28/Feb/2004') 輸出:2004-02-29 00:00:00.000 select DATEADD(DD,1,'28/Feb/2000') 輸出:2000-02-29 00:00:00.000 select DATEADD(DD,1,'28/Feb/1996')
輸出:1996-02-29 00:00:00.000
SQL語句沒有出現異常。
select N'上海長寧店'
在字符串前面加上 N 代表存入數據庫時以 Unicode 格式存儲。
N'string' 表示string是個Unicode字符串
Unicode 字符串的格式與普通字符串相似,但它前面有一個 N 標識符(N 代表 SQL-92 標準中的國際語言 (National Language))。N 前綴必須是大寫字母。例如,'Michél' 是字符串常量而 N'Michél' 則是 Unicode 常量。Unicode 常量被解釋為 Unicode 數據,并且不使用代碼頁進行計算。Unicode 常量確實有排序規(guī)則,主要用于控制比較和區(qū)分大小寫。為 Unicode 常量指派當前數據庫的默認排序規(guī)則,除非使用 COLLATE 子句為其指定了排序規(guī)則。Unicode 數據中的每個字符都使用兩個字節(jié)進行存儲,而字符數據中的每個字符則都使用一個字節(jié)進行存儲。有關更多信息,請參見使用 Unicode 數據。
Unicode 字符串常量支持增強的排序規(guī)則。
作者:Tyler Ning
出處:http://www.rzrgm.cn/tylerdonet/
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,如有問題,請微信聯系冬天里的一把火
浙公網安備 33010602011771號