共計 1515 個字符,預計需要花費 4 分鐘才能閱讀完成。
這篇文章給大家介紹如何將數據庫 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 添加了根節點“業務信息”。
關于如何將數據庫 SQL 查詢結果直接轉為 JSON 就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。