您好,登錄后才能下訂單哦!
這篇文章給大家介紹Mysql數據庫中如何實現查詢JSON函數,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
JSON 格式字段是 Mysql 5.7 新加的屬性,不夠它本質上以字符串性質保存在庫中的,剛接觸時我只了解 $.xx 查詢字段的方法,因為大部分時間,有這個就夠了,其他交給程序就行了,但是最近一些操作需要更復雜的查詢操作,所以趕緊了解下更多的方法。
JSON_EXTRACT(json_doc [,path])
查詢字段
mysql> set @j = '{"name":"wxnacy"}'; mysql> select JSON_EXTRACT(@j, '$.name'); +----------------------------+ | JSON_EXTRACT(@j, '$.name') | +----------------------------+ | "wxnacy" | +----------------------------+
還有一種更簡潔的方式,但是只能在查詢表時使用
mysql> select ext -> '$.name' from test; +-----------------+ | ext -> '$.name' | +-----------------+ | "wxnacy" | +-----------------+
在 $. 后可以正常的使用 JSON 格式獲取數據方式,比如數組
mysql> set @j = '{"a": [1, 2]}'; mysql> select JSON_EXTRACT(@j, '$.a[0]'); +----------------------------+ | JSON_EXTRACT(@j, '$.a[0]') | +----------------------------+ | 1 | +----------------------------+
JSON_DEPTH(json_doc)
計算 JSON 深度,計算方式 {} [] 有一個符號即為一層,符號下有數據增加一層,復雜 JSON 算到最深的一次為止,官方文檔說 null 值深度為 0,但是實際效果并非如此,列舉幾個例子
JSON_LENGTH(json_doc [, path])
計算 JSON 最外層或者指定 path 的長度,標量的長度為1。數組的長度是數組元素的數量,對象的長度是對象成員的數量。
mysql> SELECT JSON_LENGTH('[1, 2, {"a": 3}]'); +---------------------------------+ | JSON_LENGTH('[1, 2, {"a": 3}]') | +---------------------------------+ | 3 | +---------------------------------+ mysql> SELECT JSON_LENGTH('{"a": 1, "b": {"c": 30}}'); +-----------------------------------------+ | JSON_LENGTH('{"a": 1, "b": {"c": 30}}') | +-----------------------------------------+ | 2 | +-----------------------------------------+ mysql> SELECT JSON_LENGTH('{"a": 1, "b": {"c": 30}}', '$.b'); +------------------------------------------------+ | JSON_LENGTH('{"a": 1, "b": {"c": 30}}', '$.b') | +------------------------------------------------+ | 1 | +------------------------------------------------+
JSON_TYPE(json_doc)
返回一個utf8mb4字符串,指示JSON值的類型。 這可以是對象,數組或標量類型,如下所示:
mysql> SET @j = '{"a": [10, true]}'; mysql> SELECT JSON_TYPE(@j); +---------------+ | JSON_TYPE(@j) | +---------------+ | OBJECT | +---------------+ mysql> SELECT JSON_TYPE(JSON_EXTRACT(@j, '$.a')); +------------------------------------+ | JSON_TYPE(JSON_EXTRACT(@j, '$.a')) | +------------------------------------+ | ARRAY | +------------------------------------+ mysql> SELECT JSON_TYPE(JSON_EXTRACT(@j, '$.a[0]')); +---------------------------------------+ | JSON_TYPE(JSON_EXTRACT(@j, '$.a[0]')) | +---------------------------------------+ | INTEGER | +---------------------------------------+ mysql> SELECT JSON_TYPE(JSON_EXTRACT(@j, '$.a[1]')); +---------------------------------------+ | JSON_TYPE(JSON_EXTRACT(@j, '$.a[1]')) | +---------------------------------------+ | BOOLEAN | +---------------------------------------+
可能的返回類型
純JSON類型:
數字類型:
時間類型:
字符串類型:
STRING:MySQL utf8字符類型標量:CHAR,VARCHAR,TEXT,ENUM和SET
二進制類型:
BLOB:MySQL二進制類型標量,包括BINARY,VARBINARY,BLOB和BIT
所有其他類型:
OPAQUE(原始位)
JSON_VALID
返回0或1以指示值是否為有效JSON。 如果參數為NULL,則返回NULL。
mysql> SELECT JSON_VALID('{"a": 1}'); +------------------------+ | JSON_VALID('{"a": 1}') | +------------------------+ | 1 | +------------------------+ mysql> SELECT JSON_VALID('hello'), JSON_VALID('"hello"'); +---------------------+-----------------------+ | JSON_VALID('hello') | JSON_VALID('"hello"') | +---------------------+-----------------------+ | 0 | 1 | +---------------------+-----------------------+
關于Mysql數據庫中如何實現查詢JSON函數就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。