日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 芯聞號(hào) > 充電吧
[導(dǎo)讀]測試一下基本的,從查詢結(jié)果里面構(gòu)造一個(gè)json 的格式create?table?t1(ID?int?identity,name?nvarchar(50),Chinese?int?,Math?int)

測試一下基本的,從查詢結(jié)果里面構(gòu)造一個(gè)json 的格式

create?table?t1(ID?int?identity,name?nvarchar(50),Chinese?int?,Math?int)

insert?into?t1?values?('張三',90,80),('李四',75,90),('王五',68,100)
select?*?from?t1

select?*?from?t1?for?json?auto


--查詢結(jié)果
ID??????????name???????????????????????????????????????????????Chinese?????Math
-----------?--------------------------------------------------?-----------?-----------
1???????????張三?????????????????????????????????????????????????90??????????80
2???????????李四?????????????????????????????????????????????????75??????????90
3???????????王五?????????????????????????????????????????????????68??????????100

--json?格式
[{"ID":1,"name":"張三","Chinese":90,"Math":80},{"ID":2,"name":"李四","Chinese":75,"Math":90},{"ID":3,"name":"王五","Chinese":68,"Math":100}]

?這個(gè)是默認(rèn)模式下面使用json的查詢結(jié)果。是不是十分清晰

然后我們?cè)俳釉賲?,第二波是這樣紙的。假如我們要繼續(xù)搞有層級(jí)關(guān)系的。我們還可以這樣寫。比方說把成績放在一個(gè)叫points 的節(jié)點(diǎn)里面, 也是可以分層的

select?ID,
????????name,
????????Chinese?as?[Points.Chinese],
????????Math?as?[Points.Math]
????from?t1?for?json?path


--結(jié)果json
[
{"ID":1,"name":"張三","Points":{"Chinese":90,"Math":80}},
{"ID":2,"name":"李四","Points":{"Chinese":75,"Math":90}},
{"ID":3,"name":"王五","Points":{"Chinese":68,"Math":100}}
]

他們的分?jǐn)?shù)就放在了json 里面的,被一個(gè)point 包住了。

如果說我要在這個(gè)結(jié)果里面添加一個(gè)頭來包住,當(dāng)然,我可以使用每個(gè)列來個(gè)別名 [root.col] 來實(shí)現(xiàn),然而就有點(diǎn)啰嗦了。所以我們可以使用這個(gè)root 的關(guān)鍵字來添加一個(gè)頂節(jié)點(diǎn)

select?ID,
????????name,
????????Chinese?as?[Points.Chinese],
????????Math?as?[Points.Math]
????from?t1?for?json?path,root('root')?

--返回的json結(jié)果
{"root":[
????{"ID":1,"name":"張三","Points":{"Chinese":90,"Math":80}},????{"ID":2,"name":"李四","Points":{"Chinese":75,"Math":90}},{"ID":3,"name":"王五","Points":{"Chinese":68,"Math":100}}]}

當(dāng)然咯,查詢嘛,錄入數(shù)據(jù)總是難免遇到null值,在這方面,for json 是如何處理的呢? 我在測試表添加一條數(shù)據(jù)在來查詢

insert?into?t1?values?('趙六',100,null)


select?ID,
????????name,
????????Chinese?as?[Points.Chinese],
????????Math?as?[Points.Math]
????from?t1?
????????where?id?in(3,?4)
????for?json?auto

--json的返回結(jié)果
[{"ID":3,"name":"王五","Points.Chinese":68,"Points.Math":100},{"ID":4,"name":"趙六","Points.Chinese":100}]

auto 模式下,如果是空值,將會(huì)忽略該屬性。這樣的話很容易就每一個(gè)集合返回的屬性數(shù)量都不一來,這樣不好看。所以應(yīng)對(duì)這種情況,我們可以使用 incluede_null_values 關(guān)鍵字,即使是空值,也帶出來?

select?ID,
????????name,
????????Chinese?as?[Points.Chinese],
????????Math?as?[Points.Math]
????from?t1?
????????where?id?in(3,?4)
????for?json?auto,?include_null_values

--json?的返回結(jié)果
[{"ID":3,"name":"王五","Points.Chinese":68,"Points.Math":100},{"ID":4,"name":"趙六","Points.Chinese":100,"Points.Math":null}]

使用了這個(gè)關(guān)鍵字,就可以把空值帶出來,里面的值是Null 值

?

好,本次實(shí)驗(yàn)到此為止~然后我試下解析json 的語法之類的再分享~

感想就是其實(shí)語法應(yīng)該跟xml類型的相差無幾~但是數(shù)據(jù)庫之前支持了xml 數(shù)據(jù)類型,然后json卻只能通過字符串去轉(zhuǎn)換解析。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀

序列化是將數(shù)據(jù)結(jié)構(gòu)轉(zhuǎn)換為可傳輸或存儲(chǔ)的格式,反序列化是還原為原始數(shù)據(jù)結(jié)構(gòu)。它們用于跨網(wǎng)絡(luò)傳輸、跨語言交互和持久化存儲(chǔ)。Go語言中,gob適合內(nèi)部高效傳輸,json適合跨語言交互和文本存儲(chǔ)。

關(guān)鍵字: 序列化 反序列化 json

前言sql優(yōu)化是一個(gè)大家都比較關(guān)注的熱門話題,無論你在面試,還是工作中,都很有可能會(huì)遇到。如果某天你負(fù)責(zé)的某個(gè)線上接口,出現(xiàn)了性能問題,需要做優(yōu)化。那么你首先想到的很有可能是優(yōu)化sql語句,因?yàn)樗母脑斐杀鞠鄬?duì)于代碼來說...

關(guān)鍵字: sql

無論是開發(fā)、測試,還是DBA,都難免會(huì)涉及到數(shù)據(jù)庫的操作,比如:創(chuàng)建某張表,添加某個(gè)字段、添加數(shù)據(jù)、更新數(shù)據(jù)、刪除數(shù)據(jù)、查詢數(shù)據(jù)等等。

關(guān)鍵字: 數(shù)據(jù)庫 sql

前言 上一篇總結(jié)了Mysql的鎖機(jī)制,通過讀者的反映和閱讀量顯示,總體還是不錯(cuò)的,感興趣的可以閱讀一下[大廠面試官必問的Mysql鎖機(jī)制]。 寫了那么多的Mysql文章,有讀者問我是不是dba,工作真的需要掌握那么深嗎。...

關(guān)鍵字: sql

前言 前幾天有粉絲和我聊到他找工作面試大廠時(shí)被問的問題,因?yàn)楝F(xiàn)在疫情期間,找工作也特別難找。他說面試的題目也比較難,都偏向于一兩年的工作經(jīng)驗(yàn)的面試題。 他說在一面的時(shí)候被問到Mysql的面試題,索引那塊自己都回答比較滿意...

關(guān)鍵字: sql

先看一下我要實(shí)現(xiàn)的功能界面: 這個(gè)界面的功能在圖中已有展現(xiàn),課程分配(教師教授哪門課程)在之前的頁面中已做好。這個(gè)頁面主要實(shí)現(xiàn)的是授課,即給老師教授的課程分配學(xué)生。此頁面實(shí)現(xiàn)功能的步驟已

關(guān)鍵字: json 數(shù)據(jù)庫

Json的簡單介紹從結(jié)構(gòu)上看,所有的數(shù)據(jù)最終都可以分成三種類型:第一種類型是scalar(標(biāo)量),也就是一個(gè)單獨(dú)的string(字符串)或數(shù)字(numbers),比如“北京”這個(gè)單獨(dú)的詞。第二種類型是

關(guān)鍵字: json qmljson解析

1.一般我們?cè)谶M(jìn)行客戶端和服務(wù)端交換數(shù)據(jù)的時(shí)候,會(huì)使用Json來進(jìn)行數(shù)據(jù)的傳輸,即轉(zhuǎn)換成字符串類型的json數(shù)據(jù)來進(jìn)行數(shù)據(jù)的交換。 2.Json類型的數(shù)據(jù)一般是 JSONObject

關(guān)鍵字: java json

? ? ? ? ? ? ? ? ? ? ? ? 我所寫的項(xiàng)目是使用Maven開發(fā),在pom.xml中添加如下必要依賴: ? ? ? ? 添加com.microsoft.sqlserver的mssql-

關(guān)鍵字: server sql 存儲(chǔ)過程

console.log(obj.zz+"-->獲取好友:->>>>>>>"); var fs=require('fs'); var JsonObjString=fs.readF

關(guān)鍵字: javascript json
關(guān)閉