文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL之JSON类型字段的使用技巧分享

2024-04-02 19:55

关注

测试环境: mysql8.0.19

准备工作

CREATE TABLE json_demo ( 
	`id` INT ( 11 ) NOT NULL PRIMARY KEY, 
	`content` json NOT NULL 
);
INSERT INTO json_demo ( id, content )
VALUES
	
	( 1, '[{"key": 1, "order": 1, "value": "34252"},{"key": 2, "order": 2, "value": "23423"}]' ),
	
	( 2, '[{"key": 4, "order": 4, "value": "234"},{"key": 5, "order": 5, "value": "234324523"}]' ),
	
	( 3, '{"key": 3, "order": 3, "value": "43242"}' ),
	
	( 4, '{"key": 6, "order": 6, "value": "5423"}' );

JSON对象基础操作

查询指定字段值


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;

MySQL之JSON类型字段的使用技巧分享

TIPS:

用于条件查询

content -> '$.key'可以看成一个字段,一个字段能做的操作基本他都能。

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%';

MySQL之JSON类型字段的使用技巧分享

修改指定字段值


UPDATE json_demo 
SET content = JSON_REPLACE(
	content,
	
	'$.key', content -> '$.key' + 1,
	
	'$.value', concat(content ->> '$.value', 'abc')
) WHERE id = 3;

UPDATE json_demo 
SET content = JSON_SET(
	content,
	
	'$.key', content -> '$.key' + 1,
	
	'$.value', concat(content ->> '$.value', 'abc')
) WHERE id = 3;

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;

MySQL之JSON类型字段的使用技巧分享

TIPS:

追加元素

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;

MySQL之JSON类型字段的使用技巧分享

JSON数组操作

查询指定字段值

SELECT
	id,
	content -> '$[*].key' AS 'key',
	content ->> '$[*].value' AS 'value',
	content -> '$[0].key' AS 'key2',
	content ->> '$[0].value' AS 'value2',
	
	JSON_LENGTH(content) AS 'length'
FROM
	json_demo 
WHERE
	id < 3;

MySQL之JSON类型字段的使用技巧分享

用于条件查询

SELECT
	id,
	content -> '$[*].key' AS 'key',
	content ->> '$[*].value' AS 'value'
FROM
	json_demo 
WHERE
	id < 3
	
	AND content ->> '$[*].value' like '%34%'
	
	AND JSON_OVERLAPS(content ->> '$[*].key', '4' );

MySQL之JSON类型字段的使用技巧分享

修改指定字段值

基础操作都跟JSON对象差不太多,就是在'$'后面加对应的索引位'$[0]',指定所有则'$[*]'。如果数组中包含数组,可以通过'$[1][2][3]'这种方式指定深层的数组元素。

MySQL之JSON类型字段的使用技巧分享

追加元素

JSON_ARRAY_APPEND和JSON_ARRAY_INSERT都可以实现数组元素追加。区别在于JSON_ARRAY_APPEND可以不指定索引位,此时往最后位置追加;JSON_ARRAY_INSERT必须指定索引位,不指定则会报错。

JSON_ARRAY_APPEND是追加在指定索引位后面,而JSON_ARRAY_INSERT则是插入到指定索引位前面。

MySQL之JSON类型字段的使用技巧分享

更多操作

名称描述
JSON_ARRAY()创建JSON数组
JSON_ARRAY_APPEND()将数据附加到JSON文档
JSON_ARRAY_INSERT()插入JSON数组
JSON_CONTAINS()JSON文档是否在路径中包含特定对象
JSON_CONTAINS_PATH()JSON文档是否在路径中包含任何数据
JSON_DEPTH()JSON文档的最大深度
JSON_EXTRACT()从JSON文档返回数据
JSON_INSERT()将数据插入JSON文档
JSON_KEYS()JSON文档中的键数组
JSON_LENGTH()JSON文档中的元素数
JSON_MERGE() (已弃用)合并JSON文档,保留重复的键。JSON_MERGE_PRESERVE()的已弃用同义词
JSON_MERGE_PATCH()合并JSON文档,替换重复键的值
JSON_MERGE_PRESERVE()合并JSON文档,保留重复的键
JSON_OBJECT()创建JSON对象
JSON_OVERLAPS() (8.0.17引入)比较两个JSON文档,如果它们具有共同的任何键值对或数组元素,则返回TRUE(1),否则返回FALSE(0)
JSON_PRETTY()以易于阅读的格式打印JSON文档
JSON_QUOTE()引用JSON文档
JSON_REMOVE()从JSON文档中删除数据
JSON_REPLACE()替换JSON文档中的值
JSON_SCHEMA_VALID() (8.0.17引入)根据JSON模式验证JSON文档;如果文档针对架构进行了验证,则返回TRUE / 1;否则,则返回FALSE / 0。
JSON_SCHEMA_VALIDATION_REPORT() (8.0.17引入)根据JSON模式验证JSON文档;以JSON格式返回有关验证结果的报告,包括成功或失败以及失败原因
JSON_SEARCH()JSON文档中值的路径
JSON_SET()将数据插入JSON文档
JSON_STORAGE_FREE()部分更新后,JSON列值的二进制表示形式中的可用空间
JSON_STORAGE_SIZE()用于存储JSON文档的二进制表示形式的空间
JSON_TABLE()从JSON表达式返回数据作为关系表
JSON_TYPE()JSON值类型
JSON_UNQUOTE()取消引用JSON值
JSON_VALID()JSON值是否有效
JSON_VALUE() (8.0.21引入)在提供的路径所指向的位置从JSON文档中提取值;以VARCHAR(512)或指定的类型返回此值
MEMBER OF() (8.0.17引入)如果第一个操作数与作为第二个操作数传递的JSON数组的任何元素匹配,则返回true(1),否则返回false(0)

JSON字段在JAVA中的实践

这个是我的另外一篇关于JSON字段实践:

Mysql json类型字段Java+MyBATis数据字典功能实践

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯