欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

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

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

創(chuàng)新互聯(lián)公司是網(wǎng)站建設(shè)專家,致力于互聯(lián)網(wǎng)品牌建設(shè)與網(wǎng)絡(luò)營銷,專業(yè)領(lǐng)域包括成都網(wǎng)站制作、網(wǎng)站設(shè)計、電商網(wǎng)站制作開發(fā)、小程序制作、微信營銷、系統(tǒng)平臺開發(fā),與其他網(wǎng)站設(shè)計及系統(tǒng)開發(fā)公司不同,我們的整合解決方案結(jié)合了恒基網(wǎng)絡(luò)品牌建設(shè)經(jīng)驗和互聯(lián)網(wǎng)整合營銷的理念,并將策略和執(zhí)行緊密結(jié)合,且不斷評估并優(yōu)化我們的方案,為客戶提供全方位的互聯(lián)網(wǎng)品牌整合方案!

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

SQL與Json

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

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

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

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

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);
如何將數(shù)據(jù)庫SQL查詢結(jié)果直接轉(zhuǎn)為JSON 

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

神奇的for json auto子句

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

select *from @sale for json auto

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

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

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

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

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

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

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

神奇的for json path子句

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

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

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

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

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

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

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

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

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

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

神奇的ROOT選項

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

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

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

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

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

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

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

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

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

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

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

當(dāng)前文章:如何將數(shù)據(jù)庫SQL查詢結(jié)果直接轉(zhuǎn)為JSON
URL鏈接:http://chinadenli.net/article26/pgpjjg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計、電子商務(wù)、外貿(mào)建站、企業(yè)網(wǎng)站制作、網(wǎng)站內(nèi)鏈、網(wǎng)頁設(shè)計公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管