我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

测试环境: 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:

  • ->和->>是MySQL设计的语法,其中->在MySQL5.7支持,->>在MySQL8.0中支持。
  • ->等效于JSON_EXTRACT(),当查询字段为字符串时,其返回值还会带有""。
  • ->>等效于JSON_UNQUOTE(JSON_EXTRACT()),当查询字段为字符串时,其返回值不会带有""。

用于条件查询

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:

  • JSON_REPLACE和JSON_SET都可以用来修改某个字段值,区别在于JSON_REPLACE替换不存在的属性时操作无效;而JSON_SET则会将这个不存在的属性插入进去。
  • 所以JSON_SET也可以用来追加属性,与JSON_INSERT类似。区别在于JSON_INSERT如果插入一个已存在的属性时操作会失效,而JSON_SET会替换。

追加元素

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

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql中json类型字段的基本用法实例

目录前言基本环境jsON类型字段常用操作插入JSON类型数据查询JSON类型数据更新JSON类型数据中的特定字段匹配JSON类型数据中的特定字段结语前言mysql从5.7.8版本开始原生支持了JSON类型数据,同时可以对JSON类型字段中
2022-08-12

分享MySQL中锁的使用技巧

MySQL 锁的使用技巧分享随着数据库应用的日益广泛,对数据库的并发控制和数据完整性要求也越来越高。在MySQL数据库中,锁是一种重要的并发控制手段,可以有效地保护数据的完整性和一致性。本文将对MySQL锁的使用技巧进行详细分享,并提供具体
分享MySQL中锁的使用技巧
2023-12-21

MySQL中使用CTE获取时间段数据的技巧分享

目录引言1. 获取最近十二个月解释:2. 获取最近十二周解释:3. 获取最近四个季度解释:4. 获取十二个月前的月第一天解释:5. 获取十二周前的周第一天解释:结论引言在数据库操作中,获取特定时间段的数据是一项常见任务。mysql自从8.
MySQL中使用CTE获取时间段数据的技巧分享
2024-08-21

mysql enum字段类型的谨慎使用

目录为什么使用枚举枚举类型使用陷阱使用例子:插入数字例子:为什么使用枚举限定值的取值范围,比如性别(男,女,未知)等。枚举类型使用陷阱1.超级不推荐在mysql中设置某一字段类型为enum,但是存的值为数字,比如‘0&rs
2022-07-14

JSON字段类型在ORM中的使用是怎么样的

JSON字段类型在ORM中的使用是怎么样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。JSON字段类型在ORM中的使用  ThinkPHP5.1版本正式发布已
2023-06-02

Postgresql数据库中的json类型字段使用示例详解

目录1. json概述2. PostgreSQL数据库中使用Json类型字段2.1. 创建表定义字段信息2.2. 增加2.3. 查询键值2.3.1. 查询键2.3.2. 查询值2.3.3. where查询条件使android用json键值作
2023-02-09

使用numpy进行数据类型转换的实用技巧和案例分析

numpy数据类型转换的实用技巧与案例分析导语:在数据分析和科学计算的过程中,经常需要对数据进行类型转换以适应不同的计算需求。numpy作为Python中常用的科学计算库,提供了丰富的数据类型转换函数和方法,本文将介绍numpy中数据类型
使用numpy进行数据类型转换的实用技巧和案例分析
2024-01-26

编程热搜

目录