將數據庫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);

演示數據
神奇的for json auto子句
在查詢的from子句中加上 for json auto,查詢結果就會自動轉成json文本,這是最簡單的一種轉換方式。
- select *from @sale for json auto
查詢的結果就是json文本了。

查詢結果自動轉成Json
把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文本:

查詢結果自動轉成Json
把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文本:

查詢結果自動轉成Json
把Json抓取出來,效果如下:

自動導出的Json文本
可以看到Json添加了根節點“業務信息”。
希望對您有所幫助!