時(shí)間:2024-03-26 14:33作者:下載吧人氣:15
結(jié)合近期接觸到的知識(shí)點(diǎn),做了一個(gè)歸納。會(huì)持續(xù)更新
json
官網(wǎng)文檔 http://www.postgres.cn/docs/12/datatype-json.html
總結(jié):json輸入快,處理慢。是精準(zhǔn)拷貝,所以能準(zhǔn)確存儲(chǔ)遺留對(duì)象的原格式,如對(duì)象鍵順序。jsonb輸入慢,處理快。會(huì)被重新解析成json數(shù)據(jù),不保存原對(duì)象的鍵順序,并且去重相同的鍵值,以最后一個(gè)為準(zhǔn)。通常,除非有特別特殊的需要(例如遺留的對(duì)象鍵順序假設(shè)),大多數(shù)應(yīng)用應(yīng)該 更愿意把 JSON 數(shù)據(jù)存儲(chǔ)為jsonb
官網(wǎng):
json 和 jsonb數(shù)據(jù)類型接受***幾乎***完全相同的值集合作為輸入。 主要的實(shí)際區(qū)別之一是效率。json數(shù)據(jù)類型存儲(chǔ)輸入文本的精準(zhǔn)拷貝,處理函數(shù)必須在每 次執(zhí)行時(shí)必須重新解析該數(shù)據(jù)。而jsonb數(shù)據(jù)被存儲(chǔ)在一種分解好的 二進(jìn)制格式中,它在輸入時(shí)要稍慢一些,因?yàn)樾枰龈郊拥霓D(zhuǎn)換。但是 jsonb在處理時(shí)要快很多,因?yàn)椴恍枰馕?。jsonb也支 持索引,這也是一個(gè)令人矚目的優(yōu)勢(shì)。
由于json類型存儲(chǔ)的是輸入文本的準(zhǔn)確拷貝,其中可能會(huì)保留在語(yǔ)法 上不明顯的、存在于記號(hào)之間的空格,還有 JSON 對(duì)象內(nèi)部的鍵的順序。還有, 如果一個(gè)值中的 JSON 對(duì)象包含同一個(gè)鍵超過(guò)一次,所有的鍵/值對(duì)都會(huì)被保留( 處理函數(shù)會(huì)把最后的值當(dāng)作有效值)。相反,jsonb不保留空格、不 保留對(duì)象鍵的順序并且不保留重復(fù)的對(duì)象鍵。如果在輸入中指定了重復(fù)的鍵,只有 最后一個(gè)值會(huì)被保留。
通常,除非有特別特殊的需要(例如遺留的對(duì)象鍵順序假設(shè)),大多數(shù)應(yīng)用應(yīng)該 更愿意把 JSON 數(shù)據(jù)存儲(chǔ)為jsonb
由于json類型存儲(chǔ)的是輸入文本的準(zhǔn)確拷貝,其中可能會(huì)保留在語(yǔ)法 上不明顯的、存在于記號(hào)之間的空格,還有 JSON 對(duì)象內(nèi)部的鍵的順序。還有, 如果一個(gè)值中的 JSON 對(duì)象包含同一個(gè)鍵超過(guò)一次,所有的鍵/值對(duì)都會(huì)被保留( 處理函數(shù)會(huì)把最后的值當(dāng)作有效值)。相反,jsonb不保留空格、不 保留對(duì)象鍵的順序并且不保留重復(fù)的對(duì)象鍵。如果在輸入中指定了重復(fù)的鍵,只有 最后一個(gè)值會(huì)被保留。
———–1.鍵的順序
SELECT ‘{“bar”: “baz”, “balance”: 7.77, “active”:false}’::json;
json
————————————————-
{“bar”: “baz”, “balance”: 7.77, “active”:false}
(1 row)
SELECT ‘{“bar”: “baz”, “balance”: 7.77, “active”:false}’::jsonb;
jsonb
————————————————–
{“bar”: “baz”, “active”: false, “balance”: 7.77}
(1 row)
———2.去重
SELECT ‘{“bar”: “baz”, “balance”: 7.77, “balance”:false}’::jsonb; –去重
{“bar”: “baz”, “balance”: false}
SELECT ‘{“bar”: “baz”, “balance”: 7.77, “balance”:false}’::json; –不去重
{“bar”: “baz”, “balance”: 7.77, “balance”:false}
select ‘[1, 2, 2]’::jsonb –數(shù)組不去重
[1, 2, 2]
網(wǎng)友評(píng)論