成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

將數(shù)據(jù)庫SQL查詢結(jié)果直接轉(zhuǎn)為JSON

數(shù)據(jù)庫
JSON是一種輕量級(jí)的數(shù)據(jù)交換格式,采用完全獨(dú)立于編程語言的文本格式來存儲(chǔ)和表示數(shù)據(jù)。簡潔和清晰的層次結(jié)構(gòu)使得 JSON 成為理想的數(shù)據(jù)交換語言。易于人閱讀和編寫,同時(shí)也易于機(jī)器解析和生成,并有效地提升網(wǎng)絡(luò)傳輸效率。

JSON是一種輕量級(jí)的數(shù)據(jù)交換格式,采用完全獨(dú)立于編程語言的文本格式來存儲(chǔ)和表示數(shù)據(jù)。簡潔和清晰的層次結(jié)構(gòu)使得 JSON 成為理想的數(shù)據(jù)交換語言。易于人閱讀和編寫,同時(shí)也易于機(jī)器解析和生成,并有效地提升網(wǎng)絡(luò)傳輸效率。 

[[254654]] 

SQL與Json

SQLServer對(duì)從2016開始添加了對(duì)Json數(shù)據(jù)的支持,我們可以很輕松的將查詢的數(shù)據(jù)通過SQL語句直接轉(zhuǎn)成Json格式,這對(duì)我們存儲(chǔ)和交互數(shù)據(jù)提供了一個(gè)很好的途徑。

今天我們就說說在SQLServer中如何將查詢結(jié)果生成Json文本。

測(cè)試數(shù)據(jù)準(zhǔn)備

為了測(cè)試效果,我們先準(zhǔn)備測(cè)試數(shù)據(jù),這里做一個(gè)簡單的銷售表: 

  1. declare @sale table(  
  2.  FName nvarchar(50),  
  3.  FDistrict nvarchar(50),  
  4.  FAmount decimal(28,10)  
  5. ); 
  6.  
  7. insert into @sale  
  8. values  
  9. ('張三','北京',20000),  
  10. ('張三','上海',50000),  
  11. ('張三','深圳',40000),  
  12. ('張三','廣州',30000),  
  13. ('李四','北京',30000),  
  14. ('李四','上海',50000),  
  15. ('李四','深圳',40000),  
  16. ('李四','廣州',10000);  
 

演示數(shù)據(jù)

神奇的for json auto子句

在查詢的from子句中加上 for json auto,查詢結(jié)果就會(huì)自動(dòng)轉(zhuǎn)成json文本,這是最簡單的一種轉(zhuǎn)換方式。 

  1. select *from @sale for json auto 

查詢的結(jié)果就是json文本了。 

 

查詢結(jié)果自動(dòng)轉(zhuǎn)成Json

把Json抓取出來,效果如下: 

 

自動(dòng)導(dǎo)出的Json文本

是否感覺很神奇,如果您覺得SQLServer對(duì)導(dǎo)出Json的支持僅僅如此,那您就太小看微軟了,下面我們?cè)僬f說更強(qiáng)大的導(dǎo)出功能。

神奇的for json path子句

見識(shí)了神奇的for json auto子句,我們?cè)诳纯戳硪粋€(gè)神奇的for json path子句,該子句使用列別名或列名來確定 JSON 輸出中的鍵名稱。

比如我們把“姓名”作為一個(gè)頂層節(jié)點(diǎn),把區(qū)域和銷售額設(shè)置一個(gè)上級(jí)節(jié)點(diǎn)“銷售情況”: 

  1. select FName as 姓名,  
  2.  FDistrict as '銷售情況.區(qū)域',  
  3.  FAmount as '銷售情況.金額'  
  4. from @sale   
  5. for json path 

查詢的結(jié)果也是Json文本:

 

 

查詢結(jié)果自動(dòng)轉(zhuǎn)成Json

把Json抓取出來,效果如下: 

 

自動(dòng)導(dǎo)出的Json文本

有沒有發(fā)現(xiàn)什么不同?“銷售情況.區(qū)域”、“銷售情況.金額”中的點(diǎn)號(hào),自動(dòng)將“銷售情況”作為了上級(jí)節(jié)點(diǎn),“區(qū)域”和“金額”作為了子節(jié)點(diǎn)。

神奇的ROOT選項(xiàng)

對(duì)Json比較熟悉的朋友會(huì)發(fā)現(xiàn),for json auto和for json path導(dǎo)出的Json直接是數(shù)組,每條記錄就是一個(gè)數(shù)組元素,缺少了根節(jié)點(diǎn),如果我們想要給Json加一個(gè)根節(jié)點(diǎn)要怎么做呢?

SQLServer提供了Root選項(xiàng)來完成根節(jié)點(diǎn)的添加工作: 

  1. select FName as 姓名,  
  2.  FDistrict as '銷售情況.區(qū)域',  
  3.  FAmount as '銷售情況.金額'  
  4. from @sale   
  5. for json path, root('業(yè)務(wù)信息'); 

查詢的結(jié)果仍然是Json文本: 

 

查詢結(jié)果自動(dòng)轉(zhuǎn)成Json

把Json抓取出來,效果如下: 

 

自動(dòng)導(dǎo)出的Json文本

可以看到Json添加了根節(jié)點(diǎn)“業(yè)務(wù)信息”。

希望對(duì)您有所幫助! 

責(zé)任編輯:龐桂玉 來源: 快資訊
相關(guān)推薦

2016-10-09 10:59:26

Azure SQL數(shù)據(jù)庫JSON

2016-09-07 14:08:01

AzureSQLJSON

2009-07-06 21:20:34

SQL Server數(shù)

2011-04-06 17:30:41

SQL ServerSQL

2009-11-18 16:16:51

Oracle數(shù)據(jù)庫

2011-07-28 15:53:06

SQL Server數(shù)合并查詢

2011-07-11 10:42:23

SQL數(shù)據(jù)庫橫向數(shù)據(jù)縱向字段

2009-01-27 21:00:00

服務(wù)器數(shù)據(jù)庫SQL Server

2011-08-15 16:58:34

SQL Server遠(yuǎn)程查詢批量導(dǎo)入數(shù)據(jù)

2018-02-27 15:48:31

數(shù)據(jù)庫SQL鎖死

2010-07-15 17:28:50

SQL Server

2021-01-28 09:00:00

SQL數(shù)據(jù)庫NoSQL

2024-09-29 16:11:55

NLogSQL數(shù)據(jù)庫

2011-07-21 10:00:19

SQL Server SQL Server數(shù)

2010-09-08 16:53:43

SQL查詢循環(huán)

2011-03-04 13:07:06

SQL Server數(shù)

2011-04-01 14:34:31

SQL Server數(shù)嵌套子查詢

2011-08-30 11:04:30

鏈接查詢內(nèi)連接外連接

2022-09-28 07:31:59

索引數(shù)據(jù)庫查詢

2009-04-30 09:28:05

SynonymOpenquerySQL Server
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 精品一二区 | 午夜私人影院在线观看 | 国产一区二区中文字幕 | 国产日韩精品在线 | 亚洲综合色网 | 黄色片网此 | 毛片一级网站 | 日韩精品视频在线 | 成人自拍av | 国产精品久久久久久久久久久免费看 | 青青草一区二区 | 欧美色综合一区二区三区 | 新疆少妇videos高潮 | 天天久久 | 欧美日韩亚洲一区 | 色吊丝2| av一区二区三区四区 | www.日日夜夜 | 国产成人一区二区三区久久久 | 91国内精精品久久久久久婷婷 | 亚洲国产成人精品女人久久久 | 蜜臀av日日欢夜夜爽一区 | 狠狠色综合网站久久久久久久 | 人人亚洲| 成人免费一区二区三区视频网站 | 国产精品欧美一区二区三区不卡 | 亚洲精品不卡 | 日本高清不卡视频 | 国产一区二区中文字幕 | 午夜三区 | 成人在线观看免费 | 成人免费淫片aa视频免费 | 欧美中文字幕一区二区三区亚洲 | 欧美天堂| 国产福利在线视频 | 国产成人免费在线 | 国产一区二区 | 欧美日韩在线成人 | 九九热这里只有精品在线观看 | 国产无人区一区二区三区 | 国产日韩欧美中文字幕 |