您好,登錄后才能下訂單哦!
這篇文章給大家介紹如何將數(shù)據(jù)庫SQL查詢結(jié)果直接轉(zhuǎn)為JSON,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
JSON是一種輕量級(jí)的數(shù)據(jù)交換格式,采用完全獨(dú)立于編程語言的文本格式來存儲(chǔ)和表示數(shù)據(jù)。簡(jiǎn)潔和清晰的層次結(jié)構(gòu)使得 JSON 成為理想的數(shù)據(jù)交換語言。易于人閱讀和編寫,同時(shí)也易于機(jī)器解析和生成,并有效地提升網(wǎng)絡(luò)傳輸效率。
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è)簡(jiǎn)單的銷售表:
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ù)
神奇的for json auto子句
在查詢的from子句中加上 for json auto,查詢結(jié)果就會(huì)自動(dòng)轉(zhuǎn)成json文本,這是最簡(jiǎn)單的一種轉(zhuǎn)換方式。
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)“銷售情況”:
select FName as 姓名, FDistrict as '銷售情況.區(qū)域', FAmount as '銷售情況.金額' from @sale 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)的添加工作:
select FName as 姓名, FDistrict as '銷售情況.區(qū)域', FAmount as '銷售情況.金額' from @sale 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ù)信息”。
關(guān)于如何將數(shù)據(jù)庫SQL查詢結(jié)果直接轉(zhuǎn)為JSON就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。