sql server2016里面的json功能淺析
測(cè)試一下基本的,從查詢結(jié)果里面構(gòu)造一個(gè)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 --查詢結(jié)果 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}]
這個(gè)是默認(rèn)模式下面使用json的查詢結(jié)果。是不是十分清晰
然后我們?cè)俳釉賲?,第二波是這樣紙的。假如我們要繼續(xù)搞有層級(jí)關(guān)系的。我們還可以這樣寫(xiě)。比方說(shuō)把成績(jī)放在一個(gè)叫points 的節(jié)點(diǎn)里面, 也是可以分層的
select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 for json path --結(jié)果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}} ]
他們的分?jǐn)?shù)就放在了json 里面的,被一個(gè)point 包住了。
如果說(shuō)我要在這個(gè)結(jié)果里面添加一個(gè)頭來(lái)包住,當(dāng)然,我可以使用每個(gè)列來(lái)個(gè)別名 [root.col] 來(lái)實(shí)現(xiàn),然而就有點(diǎn)啰嗦了。所以我們可以使用這個(gè)root 的關(guān)鍵字來(lái)添加一個(gè)頂節(jié)點(diǎn)
select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 for json path,root('root') --返回的json結(jié)果 {"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}}]}
當(dāng)然咯,查詢嘛,錄入數(shù)據(jù)總是難免遇到null值,在這方面,for json 是如何處理的呢? 我在測(cè)試表添加一條數(shù)據(jù)在來(lái)查詢
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的返回結(jié)果 [{"ID":3,"name":"王五","Points.Chinese":68,"Points.Math":100},{"ID":4,"name":"趙六","Points.Chinese":100}]
auto 模式下,如果是空值,將會(huì)忽略該屬性。這樣的話很容易就每一個(gè)集合返回的屬性數(shù)量都不一來(lái),這樣不好看。所以應(yīng)對(duì)這種情況,我們可以使用 incluede_null_values 關(guān)鍵字,即使是空值,也帶出來(lái)
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 的返回結(jié)果 [{"ID":3,"name":"王五","Points.Chinese":68,"Points.Math":100},{"ID":4,"name":"趙六","Points.Chinese":100,"Points.Math":null}]
使用了這個(gè)關(guān)鍵字,就可以把空值帶出來(lái),里面的值是Null 值
好,本次實(shí)驗(yàn)到此為止~然后我試下解析json 的語(yǔ)法之類的再分享~
感想就是其實(shí)語(yǔ)法應(yīng)該跟xml類型的相差無(wú)幾~但是數(shù)據(jù)庫(kù)之前支持了xml 數(shù)據(jù)類型,然后json卻只能通過(guò)字符串去轉(zhuǎn)換解析。
以上所述是小編給大家介紹的sql server2016里面的json功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
SQL Server存儲(chǔ)過(guò)程中編寫(xiě)事務(wù)處理的方法小結(jié)
這篇文章主要介紹了SQL Server存儲(chǔ)過(guò)程中編寫(xiě)事務(wù)處理的方法,結(jié)合實(shí)例形式總結(jié)分析了三種存儲(chǔ)過(guò)程中編寫(xiě)事務(wù)處理的方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-03-03不同數(shù)據(jù)庫(kù)之間導(dǎo)入導(dǎo)出功能介紹
在SQL Server中使用最廣泛的就是通過(guò)SELECT INTO語(yǔ)句導(dǎo)出數(shù)據(jù),SELECT INTO語(yǔ)句同時(shí)具備兩個(gè)功能2010-12-12分享一下SQL Server執(zhí)行動(dòng)態(tài)SQL的正確方式
這篇文章主要介紹了SQL Server執(zhí)行動(dòng)態(tài)SQL正確方式,需要的朋友可以參考下2017-06-06SQLSERVER查詢所有數(shù)據(jù)庫(kù)名,表名,和字段名的語(yǔ)句
SQLSERVER查詢所有數(shù)據(jù)庫(kù)名,表名,和字段名的語(yǔ)句,需要的朋友可以參考下。2011-12-12SQL?Server數(shù)據(jù)庫(kù)備份和恢復(fù)數(shù)據(jù)庫(kù)的全過(guò)程
最近在功能調(diào)試前需要先將測(cè)試數(shù)據(jù)庫(kù)備份,然后功能調(diào)試之后再將測(cè)試數(shù)據(jù)庫(kù)還原,這樣就可以重復(fù)的進(jìn)行功能調(diào)試,這篇文章主要給大家介紹了關(guān)于SQL?Server數(shù)據(jù)庫(kù)備份和恢復(fù)數(shù)據(jù)庫(kù)的相關(guān)資料,需要的朋友可以參考下2022-06-06