婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > sql server2016里面的json功能淺析

sql server2016里面的json功能淺析

熱門標簽:安卡拉地圖標注app 電話機器人怎么代理商 千呼電話機器人可以試用嗎 互聯網電話外呼系統 電銷需要外呼系統嗎 400電話辦理泰安 我要地圖標注數量有限制嗎 家庭農場地圖標注名稱怎樣起名 零成本地圖標注賺錢

測試一下基本的,從查詢結果里面構造一個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卻只能通過字符串去轉換解析。

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

您可能感興趣的文章:
  • windows server2016安裝MySQL5.7.19解壓縮版教程詳解
  • Sql Server2016 正式版安裝程序圖解教程
  • SQL Server2016正式版安裝配置方法圖文教程
  • SQL Server 2016 Alwayson新增功能圖文詳解

標簽:文山 黃山 池州 新鄉 大同 東營 濱州 來賓

巨人網絡通訊聲明:本文標題《sql server2016里面的json功能淺析》,本文關鍵詞  sql,server2016,里,面的,json,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《sql server2016里面的json功能淺析》相關的同類信息!
  • 本頁收集關于sql server2016里面的json功能淺析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 饶平县| 磴口县| 类乌齐县| 象山县| 方正县| 瑞金市| 杨浦区| 静海县| 山东| 呈贡县| 雷山县| 永康市| 阿勒泰市| 泊头市| 南溪县| 丰镇市| 赣州市| 会宁县| 辽源市| 沾化县| 富源县| 威宁| 连城县| 泰安市| 韶关市| 鹿邑县| 青阳县| 乌兰浩特市| 离岛区| 罗定市| 亳州市| 涿州市| 文山县| 淮南市| 军事| 准格尔旗| 外汇| 云霄县| 镇坪县| 太谷县| 湘乡市|