程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> sql server2016外面的json功用淺析

sql server2016外面的json功用淺析

編輯:MSSQL

sql server2016外面的json功用淺析。本站提示廣大學習愛好者:(sql server2016外面的json功用淺析)文章只能為提供參考,不一定能成為您想要的結果。以下是sql server2016外面的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卻只能經過字符串去轉換解析。

以上所述是給大家引見的sql server2016外面的json功用,希望對大家有所協助,假如大家有任何疑問請給我留言,會及時回復大家的。在此也十分感激大家對網站的支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved