测试环境: MySQL8.0.19

TIPS:
用于条件查询
content -> '$.key'可以看成一个字段,一个字段能做的操作基本他都能。

修改指定字段值

TIPS:
追加元素

查询指定字段值

用于条件查询

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

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

| 名称 | 描述 |
|---|---|
| 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字段实践:
Mysql json类型字段Java+Mybatis数据字典功能实践
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。