五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動態(tài)

sql server2016里面的json功能淺析

發(fā)布日期:2021-12-15 11:40 | 文章來源:gibhub

測試一下基本的,從查詢結(jié)果里面構(gòu)造一個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}]

這個是默認(rèn)模式下面使用json的查詢結(jié)果。是不是十分清晰

然后我們再接再厲,第二波是這樣紙的。假如我們要繼續(xù)搞有層級關(guān)系的。我們還可以這樣寫。比方說把成績放在一個叫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 里面的,被一個point 包住了。

如果說我要在這個結(jié)果里面添加一個頭來包住,當(dāng)然,我可以使用每個列來個別名 [root.col] 來實現(xiàn),然而就有點(diǎn)啰嗦了。所以我們可以使用這個root 的關(guān)鍵字來添加一個頂節(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 是如何處理的呢? 我在測試表添加一條數(shù)據(jù)在來查詢

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 模式下,如果是空值,將會忽略該屬性。這樣的話很容易就每一個集合返回的屬性數(shù)量都不一來,這樣不好看。所以應(yīng)對這種情況,我們可以使用 incluede_null_values 關(guān)鍵字,即使是空值,也帶出來

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}]

使用了這個關(guān)鍵字,就可以把空值帶出來,里面的值是Null 值

好,本次實驗到此為止~然后我試下解析json 的語法之類的再分享~

感想就是其實語法應(yīng)該跟xml類型的相差無幾~但是數(shù)據(jù)庫之前支持了xml 數(shù)據(jù)類型,然后json卻只能通過字符串去轉(zhuǎn)換解析。

以上所述是小編給大家介紹的sql server2016里面的json功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對本站網(wǎng)站的支持!

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部