前2天下載了一個2016的rc版本來玩一下,首先感覺是~開發者版本免費啦!!撒花!!!另外一個東西,sql server 2016能支持json 的解析和應用啦,雖然我不知道它的性能如何,先來一發測試一下功能 測試一下基本的,從查詢結果裡面構造一個json 的格式 這個是預設模式下麵使用json的查 ...
前2天下載了一個2016的rc版本來玩一下,首先感覺是~開發者版本免費啦!!撒花!!!另外一個東西,sql server 2016能支持json 的解析和應用啦,雖然我不知道它的性能如何,先來一發測試一下功能
測試一下基本的,從查詢結果裡面構造一個json 的格式
create table t1(ID int identity,name nvarchar(50),Chinese int ,Math int) insert into t1 values ('張三',90,80),('李四',75,90),('王五',68,100) select * from t1 select * from t1 for json auto --查詢結果 ID name Chinese Math ----------- -------------------------------------------------- ----------- ----------- 1 張三 90 80 2 李四 75 90 3 王五 68 100 --json 格式 [{"ID":1,"name":"張三","Chinese":90,"Math":80},{"ID":2,"name":"李四","Chinese":75,"Math":90},{"ID":3,"name":"王五","Chinese":68,"Math":100}]
這個是預設模式下麵使用json的查詢結果。是不是十分清晰
然後我們再接再厲,第二波是這樣紙的。假如我們要繼續搞有層級關係的。我們還可以這樣寫。比方說把成績放在一個叫points 的節點裡面, 也是可以分層的
select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 for json path --結果json [ {"ID":1,"name":"張三","Points":{"Chinese":90,"Math":80}}, {"ID":2,"name":"李四","Points":{"Chinese":75,"Math":90}}, {"ID":3,"name":"王五","Points":{"Chinese":68,"Math":100}} ]
他們的分數就放在了json 裡面的,被一個point 包住了。
如果說我要在這個結果裡面添加一個頭來包住,當然,我可以使用每個列來個別名 [root.col] 來實現,然而就有點啰嗦了。所以我們可以使用這個root 的關鍵字來添加一個頂節點
select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 for json path,root('root') --返回的json結果 {"root":[ {"ID":1,"name":"張三","Points":{"Chinese":90,"Math":80}}, {"ID":2,"name":"李四","Points":{"Chinese":75,"Math":90}},{"ID":3,"name":"王五","Points":{"Chinese":68,"Math":100}}]}
當然咯,查詢嘛,錄入數據總是難免遇到null值,在這方面,for json 是如何處理的呢? 我在測試表添加一條數據在來查詢
insert into t1 values ('趙六',100,null) select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 where id in(3, 4) for json auto --json的返回結果 [{"ID":3,"name":"王五","Points.Chinese":68,"Points.Math":100},{"ID":4,"name":"趙六","Points.Chinese":100}]
auto 模式下,如果是空值,將會忽略該屬性。這樣的話很容易就每一個集合返回的屬性數量都不一來,這樣不好看。所以應對這種情況,我們可以使用 incluede_null_values 關鍵字,即使是空值,也帶出來
select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 where id in(3, 4) for json auto, include_null_values --json 的返回結果 [{"ID":3,"name":"王五","Points.Chinese":68,"Points.Math":100},{"ID":4,"name":"趙六","Points.Chinese":100,"Points.Math":null}]
使用了這個關鍵字,就可以把空值帶出來,裡面的值是Null 值
好,本次實驗到此為止~然後我試下解析json 的語法之類的再分享~
感想就是其實語法應該跟xml類型的相差無幾~但是資料庫之前支持了xml 數據類型,然後json卻只能通過字元串去轉換解析。這個後面我再實驗一下