MySQL之JSON類型字段的使用技巧分享
測(cè)試環(huán)境: MySQL8.0.19
準(zhǔn)備工作
CREATE TABLE json_demo (
`id` INT ( 11 ) NOT NULL PRIMARY KEY,
`content` json NOT NULL
);
INSERT INTO json_demo ( id, content )
VALUES
/*這條是數(shù)組*/
( 1, '[{"key": 1, "order": 1, "value": "34252"},{"key": 2, "order": 2, "value": "23423"}]' ),
/*這條是數(shù)組*/
( 2, '[{"key": 4, "order": 4, "value": "234"},{"key": 5, "order": 5, "value": "234324523"}]' ),
/*這條是對(duì)象*/
( 3, '{"key": 3, "order": 3, "value": "43242"}' ),
/*這條是對(duì)象*/
( 4, '{"key": 6, "order": 6, "value": "5423"}' );
JSON對(duì)象基礎(chǔ)操作
查詢指定字段值
/* 基礎(chǔ)查詢 */ SELECT content -> '$.key' AS 'key', JSON_EXTRACT(content, '$.key') AS 'key2', content -> '$.value' AS 'value', JSON_EXTRACT(content, '$.value') AS 'value2', content ->> '$.value' AS 'value3', JSON_UNQUOTE(JSON_EXTRACT(content, '$.value')) AS 'value4' FROM json_demo WHERE id > 2;

TIPS:
- ->和->>是MySQL設(shè)計(jì)的語法,其中->在MySQL5.7支持,->>在MySQL8.0中支持。
- ->等效于JSON_EXTRACT(),當(dāng)查詢字段為字符串時(shí),其返回值還會(huì)帶有""。
- ->>等效于JSON_UNQUOTE(JSON_EXTRACT()),當(dāng)查詢字段為字符串時(shí),其返回值不會(huì)帶有""。
用于條件查詢
content -> '$.key'可以看成一個(gè)字段,一個(gè)字段能做的操作基本他都能。
SELECT id, content -> '$.key' AS 'key', content ->> '$.value' AS 'value3' FROM json_demo WHERE id > 2 AND content -> '$.key' > 1 AND content -> '$.value' like '%2%';

修改指定字段值
/* 修改 */ UPDATE json_demo SET content = JSON_REPLACE( content, /* 將content.key值 + 1 */ '$.key', content -> '$.key' + 1, /* 將content.value值后拼接'abc' */ '$.value', concat(content ->> '$.value', 'abc') ) WHERE id = 3; /* JSON_SET也可以 */ UPDATE json_demo SET content = JSON_SET( content, /* 將content.key值 + 1 */ '$.key', content -> '$.key' + 1, /* 將content.value值后拼接'abc' */ '$.value', concat(content ->> '$.value', 'abc') ) WHERE id = 3; /* 查詢修改結(jié)果 */ SELECT id,content,content -> '$.key' AS 'key',content ->> '$.value' AS 'value3' FROM json_demo WHERE id = 3; /* 重新賦值 */ UPDATE json_demo SET content = JSON_REPLACE(content,'$.key',3,'$.value','43242') WHERE id = 3;

TIPS:
- JSON_REPLACE和JSON_SET都可以用來修改某個(gè)字段值,區(qū)別在于JSON_REPLACE替換不存在的屬性時(shí)操作無效;而JSON_SET則會(huì)將這個(gè)不存在的屬性插入進(jìn)去。
- 所以JSON_SET也可以用來追加屬性,與JSON_INSERT類似。區(qū)別在于JSON_INSERT如果插入一個(gè)已存在的屬性時(shí)操作會(huì)失效,而JSON_SET會(huì)替換。
追加元素
UPDATE json_demo SET content = JSON_INSERT(content, '$.key', 234) WHERE id = 3; SELECT id,content,content -> '$.key' AS 'key' FROM json_demo WHERE id = 3; UPDATE json_demo SET content = JSON_INSERT(content, '$.temp', 234) WHERE id = 3; SELECT id,content,content -> '$.key' AS 'key' FROM json_demo WHERE id = 3; UPDATE json_demo SET content = JSON_SET(content, '$.temp2', 432) WHERE id = 3; SELECT id,content,content -> '$.key' AS 'key' FROM json_demo WHERE id = 3;

JSON數(shù)組操作
查詢指定字段值
SELECT id, content -> '$[*].key' AS 'key', content ->> '$[*].value' AS 'value', content -> '$[0].key' AS 'key2', content ->> '$[0].value' AS 'value2', /* 查詢數(shù)組長(zhǎng)度 */ JSON_LENGTH(content) AS 'length' FROM json_demo WHERE id < 3;

用于條件查詢
SELECT id, content -> '$[*].key' AS 'key', content ->> '$[*].value' AS 'value' FROM json_demo WHERE id < 3 /* content.value的值中存在like'%34%'的值 */ AND content ->> '$[*].value' like '%34%' /* content.key的值中有4 */ AND JSON_OVERLAPS(content ->> '$[*].key', '4' );

修改指定字段值
基礎(chǔ)操作都跟JSON對(duì)象差不太多,就是在'$'后面加對(duì)應(yīng)的索引位'$[0]',指定所有則'$[*]'。如果數(shù)組中包含數(shù)組,可以通過'$[1][2][3]'這種方式指定深層的數(shù)組元素。

追加元素
JSON_ARRAY_APPEND和JSON_ARRAY_INSERT都可以實(shí)現(xiàn)數(shù)組元素追加。區(qū)別在于JSON_ARRAY_APPEND可以不指定索引位,此時(shí)往最后位置追加;JSON_ARRAY_INSERT必須指定索引位,不指定則會(huì)報(bào)錯(cuò)。
JSON_ARRAY_APPEND是追加在指定索引位后面,而JSON_ARRAY_INSERT則是插入到指定索引位前面。

更多操作
| 名稱 | 描述 |
|---|---|
| JSON_ARRAY() | 創(chuàng)建JSON數(shù)組 |
| JSON_ARRAY_APPEND() | 將數(shù)據(jù)附加到JSON文檔 |
| JSON_ARRAY_INSERT() | 插入JSON數(shù)組 |
| JSON_CONTAINS() | JSON文檔是否在路徑中包含特定對(duì)象 |
| JSON_CONTAINS_PATH() | JSON文檔是否在路徑中包含任何數(shù)據(jù) |
| JSON_DEPTH() | JSON文檔的最大深度 |
| JSON_EXTRACT() | 從JSON文檔返回?cái)?shù)據(jù) |
| JSON_INSERT() | 將數(shù)據(jù)插入JSON文檔 |
| JSON_KEYS() | JSON文檔中的鍵數(shù)組 |
| JSON_LENGTH() | JSON文檔中的元素?cái)?shù) |
| JSON_MERGE() (已棄用) | 合并JSON文檔,保留重復(fù)的鍵。JSON_MERGE_PRESERVE()的已棄用同義詞 |
| JSON_MERGE_PATCH() | 合并JSON文檔,替換重復(fù)鍵的值 |
| JSON_MERGE_PRESERVE() | 合并JSON文檔,保留重復(fù)的鍵 |
| JSON_OBJECT() | 創(chuàng)建JSON對(duì)象 |
| JSON_OVERLAPS() (8.0.17引入) | 比較兩個(gè)JSON文檔,如果它們具有共同的任何鍵值對(duì)或數(shù)組元素,則返回TRUE(1),否則返回FALSE(0) |
| JSON_PRETTY() | 以易于閱讀的格式打印JSON文檔 |
| JSON_QUOTE() | 引用JSON文檔 |
| JSON_REMOVE() | 從JSON文檔中刪除數(shù)據(jù) |
| JSON_REPLACE() | 替換JSON文檔中的值 |
| JSON_SCHEMA_VALID() (8.0.17引入) | 根據(jù)JSON模式驗(yàn)證JSON文檔;如果文檔針對(duì)架構(gòu)進(jìn)行了驗(yàn)證,則返回TRUE / 1;否則,則返回FALSE / 0。 |
| JSON_SCHEMA_VALIDATION_REPORT() (8.0.17引入) | 根據(jù)JSON模式驗(yàn)證JSON文檔;以JSON格式返回有關(guān)驗(yàn)證結(jié)果的報(bào)告,包括成功或失敗以及失敗原因 |
| JSON_SEARCH() | JSON文檔中值的路徑 |
| JSON_SET() | 將數(shù)據(jù)插入JSON文檔 |
| JSON_STORAGE_FREE() | 部分更新后,JSON列值的二進(jìn)制表示形式中的可用空間 |
| JSON_STORAGE_SIZE() | 用于存儲(chǔ)JSON文檔的二進(jìn)制表示形式的空間 |
| JSON_TABLE() | 從JSON表達(dá)式返回?cái)?shù)據(jù)作為關(guān)系表 |
| JSON_TYPE() | JSON值類型 |
| JSON_UNQUOTE() | 取消引用JSON值 |
| JSON_VALID() | JSON值是否有效 |
| JSON_VALUE() (8.0.21引入) | 在提供的路徑所指向的位置從JSON文檔中提取值;以VARCHAR(512)或指定的類型返回此值 |
| MEMBER OF() (8.0.17引入) | 如果第一個(gè)操作數(shù)與作為第二個(gè)操作數(shù)傳遞的JSON數(shù)組的任何元素匹配,則返回true(1),否則返回false(0) |
JSON字段在JAVA中的實(shí)踐
這個(gè)是我的另外一篇關(guān)于JSON字段實(shí)踐:
Mysql json類型字段Java+Mybatis數(shù)據(jù)字典功能實(shí)踐
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于MySQL8.x group_by報(bào)錯(cuò)的4種解決方案
這篇文章主要介紹了關(guān)于MySQL8.x group_by報(bào)錯(cuò)的4種解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
SQL使用WHERE條件語句的項(xiàng)目實(shí)踐
本文將介紹WHERE子句中使用的通用語法,它還將概述如何在單個(gè)WHERE子句中組合多個(gè)搜索條件謂詞以更細(xì)粒度的方式過濾數(shù)據(jù),以及如何使用NOT操作符排除而不是包含滿足給定搜索條件的行,感興趣的可以了解一下2023-09-09
MySQL不使用order by實(shí)現(xiàn)排名的三種思路總結(jié)
ORDER BY語句用于根據(jù)指定的列對(duì)結(jié)果集進(jìn)行排序,在日常開發(fā)中也經(jīng)常會(huì)用到,但下面這篇文章主要給大家介紹了關(guān)于MySQL不使用order by實(shí)現(xiàn)排名的三種思路,需要的朋友可以參考下2021-06-06
clickhouse復(fù)雜時(shí)間格式的轉(zhuǎn)換方式
這篇文章主要介紹了clickhouse復(fù)雜時(shí)間格式的轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12

