麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > SQL Server > 正文

sql server2016里面的json功能淺析

2024-08-31 01:04:37
字體:
來源:轉載
供稿:網友

測試一下基本的,從查詢結果里面構造一個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 t1select * from t1 for json auto--查詢結果ID     name                        Chinese   Math----------- -------------------------------------------------- ----------- -----------1      張三                         90     802      李四                         75     903      王五                         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卻只能通過字符串去轉換解析。

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


注:相關教程知識閱讀請移步到MSSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲四播房 | 国产成人精品无人区一区 | 日韩中文字幕三区 | 欧洲精品久久久 | 欧美18一12sex性处hd | 天天天干夜夜夜操 | 精品国产高清一区二区三区 | 国产精品视频一区二区三区四区国 | 欧美一级视屏 | 久久精品观看 | 国产精品久久久久久久久久大牛 | 91美女视频在线观看 | 国产成人精品二区 | 欧美a级在线免费观看 | av不卡免费在线 | 国产午夜精品理论片a级探花 | 黄色小视频在线免费看 | 视频一区二区不卡 | 欧美一级特级 | 黄色视屏免费看 | 免费看欧美黑人毛片 | 欧美18一12sex性处hd | av资源在线 | 国产一区二区三区高清 | 99视频观看| 国产人成精品综合欧美成人 | 曰批全过程120分钟免费69 | 爱操在线| 亚洲一区二区中文 | 久久精品视频国产 | 毛片午夜 | 中国hd高清xxxxvideo | 看免费的毛片 | 精品亚洲一区二区三区 | 夜夜b| 视频在线亚洲 | 久国久产久精永久网页 | 久久精品一区二区三 | 中文字幕网址 | 久久蜜桃精品一区二区三区综合网 | 久久精品亚洲国产奇米99 |