您好,登錄后才能下訂單哦!
本篇內容介紹了“JSON和JSONB兩者有什么區別”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
JSON 與 JSONB 也是一對冤家。現在很多開源系統和開源軟件都支持 JSON 與 JSONB,比如:Postgresql 和 MongoDB 等。這也導致了面試中被問到 JSON 與 JSONB 的區別時,很多人不知所措!
今天,我們就一起來看看它們之間到底有哪些區別?
在 stackoverflow 上有一個解釋,為了方便閱讀,我貼在了下面。
首先,
hstore
是一個擴展模塊,它允許你保存key=>values
鍵值對,且鍵值都只能是text
s類型(但是,值也允許sql的NULL)json與jsonb 允許你保存一個有效的json值(定義).
例如,以下都是有效的json表示方式:
null
,true
,[1, false, "string", {"foo":"bar"}]
,{"foo":"bar", "baz":[null]}
.相比json, hstore只是它的一個很小的子集(但是,如果你只需要這個子集,也OK的)
json與jsonb的區別主要是它們的存儲方式:
json
是保存為文本格式的
jsonb
是保存為二進制格式的
這主要有三方面的影響:
jsonb
通常比json
占用更多的磁盤空間(有些情況不是)
jsonb
比json
的寫入更耗時間
json
的操作比jsonb
的操作明顯更耗時間(在操作一個json
類型值時需要每次都去解析)
當
jsonb
將在未來穩定版發行可用時,這有兩個主要使用情況,你很容易在他們之間選擇的:
如果你的應用只用json表示,PostgreSQL只用于保存與獲取時,你應該使用json
.
如果你需要在PostgreSQL中做比較多的json值的操作,或者在一些json字段上使用索引時,你應該使用jsonb
官方文檔上說:
有兩個JSON數據類型:json和jsonb。它們接受幾乎 相同的值組作為輸入。它們實際的主要差別是效率。json 數據類型存儲輸入文本的精確拷貝,處理函數必須在每個執行上重新解析;而jsonb數據以分解的二進制格式存儲,這使得它由于添加了轉換機制而在輸入上稍微慢些,但是在處理上明顯更快,因為不需要重新解析。jsonb也支持索引,這也是一個明顯的優勢。
因為json類型存儲輸入文本的精確拷貝,它將保存令牌間語義上無關緊要的空格,和JSON對象中鍵的順序。另外,如果值中的一個JSON對象多次包含相同的鍵,那么保存所有的鍵/值對。(處理函數將最后一個值當做操作值。)相比之下, jsonb不保存空格,也不保存對象鍵的順序,并且不保存重復對象鍵。如果在輸入中指定了重復的鍵,那么只保存最后一個值。
->
右操作符為int: 獲取JSON數組元素(索引從0開始)右操作符為text: 通過鍵獲取json值
->>
右操作符為int: 獲取JSON數組元素為text右操作符為text: 通過鍵獲取json值為text
其他的如 Postgresql 中常見的操作符:#>,#>>,@>,<@,?,?|,?& 等的用法建議參考官方文檔。
“JSON和JSONB兩者有什么區別”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。