亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何將數據庫SQL查詢結果直接轉為JSON

發布時間:2021-11-29 14:25:22 來源:億速云 閱讀:9795 作者:柒染 欄目:數據庫

這篇文章給大家介紹如何將數據庫SQL查詢結果直接轉為JSON,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

JSON是一種輕量級的數據交換格式,采用完全獨立于編程語言的文本格式來存儲和表示數據。簡潔和清晰的層次結構使得 JSON 成為理想的數據交換語言。易于人閱讀和編寫,同時也易于機器解析和生成,并有效地提升網絡傳輸效率。

SQL與Json

SQLServer對從2016開始添加了對Json數據的支持,我們可以很輕松的將查詢的數據通過SQL語句直接轉成Json格式,這對我們存儲和交互數據提供了一個很好的途徑。

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

測試數據準備

為了測試效果,我們先準備測試數據,這里做一個簡單的銷售表:

declare @sale table(   FName nvarchar(50),   FDistrict nvarchar(50),   FAmount decimal(28,10)  );  insert into @sale  values  ('張三','北京',20000),  ('張三','上海',50000),  ('張三','深圳',40000),  ('張三','廣州',30000),  ('李四','北京',30000),  ('李四','上海',50000),  ('李四','深圳',40000),  ('李四','廣州',10000);
如何將數據庫SQL查詢結果直接轉為JSON 

演示數據

神奇的for json auto子句

在查詢的from子句中加上 for json auto,查詢結果就會自動轉成json文本,這是最簡單的一種轉換方式。

select *from @sale for json auto

查詢的結果就是json文本了。

如何將數據庫SQL查詢結果直接轉為JSON 

查詢結果自動轉成Json

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

如何將數據庫SQL查詢結果直接轉為JSON 

自動導出的Json文本

是否感覺很神奇,如果您覺得SQLServer對導出Json的支持僅僅如此,那您就太小看微軟了,下面我們再說說更強大的導出功能。

神奇的for json path子句

見識了神奇的for json auto子句,我們在看看另一個神奇的for json path子句,該子句使用列別名或列名來確定 JSON 輸出中的鍵名稱。

比如我們把“姓名”作為一個頂層節點,把區域和銷售額設置一個上級節點“銷售情況”:

select FName as 姓名,   FDistrict as '銷售情況.區域',   FAmount as '銷售情況.金額'  from @sale   for json path

查詢的結果也是Json文本:

如何將數據庫SQL查詢結果直接轉為JSON 

查詢結果自動轉成Json

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

如何將數據庫SQL查詢結果直接轉為JSON 

自動導出的Json文本

有沒有發現什么不同?“銷售情況.區域”、“銷售情況.金額”中的點號,自動將“銷售情況”作為了上級節點,“區域”和“金額”作為了子節點。

神奇的ROOT選項

對Json比較熟悉的朋友會發現,for json auto和for json path導出的Json直接是數組,每條記錄就是一個數組元素,缺少了根節點,如果我們想要給Json加一個根節點要怎么做呢?

SQLServer提供了Root選項來完成根節點的添加工作:

select FName as 姓名,   FDistrict as '銷售情況.區域',   FAmount as '銷售情況.金額'  from @sale   for json path, root('業務信息');

查詢的結果仍然是Json文本:

如何將數據庫SQL查詢結果直接轉為JSON 

查詢結果自動轉成Json

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

如何將數據庫SQL查詢結果直接轉為JSON 

自動導出的Json文本

可以看到Json添加了根節點“業務信息”。

關于如何將數據庫SQL查詢結果直接轉為JSON就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新巴尔虎左旗| 新河县| 新绛县| 嘉定区| 金沙县| 东安县| 彝良县| 安龙县| 都匀市| 博湖县| 榆中县| 徐水县| 彝良县| 浦东新区| 色达县| 平陆县| 辰溪县| 陕西省| 奈曼旗| 栾川县| 陆河县| 八宿县| 韩城市| 日土县| 繁峙县| 宁河县| 伊春市| 康平县| 绍兴县| 大同县| 漳浦县| 宝应县| 安庆市| 黔西| 英山县| 广元市| 岱山县| 甘泉县| 萍乡市| 台中县| 榆林市|