服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - mysql5.7 新增的json字段类型用法实例分析

mysql5.7 新增的json字段类型用法实例分析

2021-01-08 15:32怀素真 Mysql

这篇文章主要介绍了mysql5.7 新增的json字段类型用法,结合实例形式分析了mysql5.7 新增的json字段类型具体功能、使用方法及操作注意事项,需要的朋友可以参考下

本文实例讲述了mysql5.7 新增的json字段类型用法。分享给大家供大家参考,具体如下:

一、我们先创建一个表,准备点数据

?
1
2
3
4
5
create table `json_test` (
 `id` int(11) unsigned not null auto_increment comment 'id',
 `json` json default null comment 'json数据',
 primary key (`id`)
) engine=innodb default charset=utf8mb4;

mysql5.7 新增的json字段类型用法实例分析

二、检索json列的字段

通过使用 -> 或 ->> 运算符检索json列的字段

?
1
select id, json->'$[0].items[0].name' from json_test;

mysql5.7 新增的json字段类型用法实例分析

?
1
select id, json->>'$[0].items[0].name' from json_test;

mysql5.7 新增的json字段类型用法实例分析

使用 -> 和 ->> 的区别是结果用了引号包裹。

三、处理json的一些函数

json_pretty(json_val) 以优雅的格式显示json值

?
1
select id, json_pretty(json) from json_test\g;

json_contains(target, candidate[, path]) 判断给定的candidate是否包含在target中,如果指定了path,则在指定路径中进行查找。

注意,注意,注意,这里的candidate如果是数字,需要用单引号包裹,如果是字符串,单引号里再加上双引号包裹。

?
1
2
select json_contains(json->'$[0].name', '"1号篮子"') from json_test;
select json_contains(json, '"1号篮子"', '$[0].name') from json_test;

json_contains_path(json_doc, one_or_all, path[, path] ...)  判断json_doc中的路径是否存在,通俗点说就是json中的key是否存在

?
1
select json_contains_path(json, 'one', '$[0].name', '$[0].test') from json_test;

第二个参数'one'表示只要有一个key存在就返回1,否则为0

?
1
select json_contains_path(json, 'all', '$[0].name', '$[0].test') from json_test;

第二个参数'all'表示所有key存在才返回1,否则为0

json_set(json_doc, path, val[, path, val] ...) 插入或更新数据并返回结果

?
1
select json_set(json, '$[0].name', '2号篮子', '$[0].test', 'test') from json_test;

我们修改$[0].name的值,并添加一个key为test,值为test的项

json_insert(json_doc, path, val[, path, val] ...) 插入数据并返回结果,但不替换现有值。

?
1
select json_insert(json, '$[0].name', '2号篮子', '$[0].exts', '扩展') from json_test;

这时$[0].name不会被更新,只会新增一个字段$[0].exts

json_replace(json_doc, path, val[, path, val] ...) 替换现有值并返回结果

?
1
select json_replace(json, '$[0].name', '替换') from json_test;

将$[0].name中的值替换成新值

json_remove(json_doc, path[, path] ...)  删除数据并返回结果

?
1
select json_remove(json, '$[0].name') from json_test;

删除$[0].name这项数据

json_keys(json_doc[, path]) 获取json文档中的所有键

?
1
select json_keys(json, '$[0]') from json_test;

获取$[0]路径下的所有键

json_length(json_doc[, path]) 获取json文档的长度

?
1
select json_length(json, '$[0]') from json_test;

获取$[0]下的元素数量

json_extract(json_doc, path[, path] ...)  返回json文档中的数据

?
1
2
select json_extract(json, '$[0]') from json_test;
select json_extract(json, '$[0].name') from json_test;

返回json文档指定路径下的数据

json_array([val[, val] ...])  创建json数组

?
1
select json_array(1, '2', true, 5.6, null, now());

json_object([key, val[, key, val] ...]) 通过键值对, 创建json对象

?
1
select json_object('name', 'xiaoxu', 'age', 28, 'height', 1.72);

注意,这里键和值要成对出现

json_merge_patch(json_doc, json_doc[, json_doc] ...)  合并json文档,如果有重复键,后面的数据覆盖前面的

?
1
select json_merge_patch('{"name":"test1"}', '{"name":"test2"}');

json_merge_preserve(json_doc, json_doc[, json_doc] ...)  合并json文档,如果有重复键,则会通过数组把值都保存起来

?
1
select json_merge_preserve('{"name":"test1"}', '{"name":"test2"}');

json_quote(string)  通过用双引号字符包裹并转义内部引号和其他字符

?
1
select json_quote('你好"世界"');

json_unquote(json_val)  将转义字符转换回普通字符

?
1
select json_unquote('你好\\t\"世界\"');

希望本文所述对大家MySQL数据库计有所帮助。

原文链接:https://www.cnblogs.com/jkko123/p/10171167.html

延伸 · 阅读

精彩推荐
  • Mysql详解MySQL中的分组查询与连接查询语句

    详解MySQL中的分组查询与连接查询语句

    这篇文章主要介绍了MySQL中的分组查询与连接查询语句,同时还介绍了一些统计函数的用法,需要的朋友可以参考下 ...

    GALAXY_ZMY5432020-06-03
  • MysqlMySQL 数据备份与还原的示例代码

    MySQL 数据备份与还原的示例代码

    这篇文章主要介绍了MySQL 数据备份与还原的相关知识,本文通过示例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...

    逆心2962019-06-23
  • Mysqlmysql 不能插入中文问题

    mysql 不能插入中文问题

    当向mysql5.5插入中文时,会出现类似错误 ERROR 1366 (HY000): Incorrect string value: '\xD6\xD0\xCE\xC4' for column ...

    MYSQL教程网5722019-11-25
  • MysqlMySQL锁的知识点总结

    MySQL锁的知识点总结

    在本篇文章里小编给大家整理了关于MySQL锁的知识点总结以及实例内容,需要的朋友们学习下。...

    别人放弃我坚持吖4362020-12-14
  • MysqlERROR: Error in Log_event::read_log_event()

    ERROR: Error in Log_event::read_log_event()

    ERROR: Error in Log_event::read_log_event(): read error, data_len: 438, event_type: 2 ...

    MYSQL教程网6402020-03-13
  • Mysql解决MySQl查询不区分大小写的方法讲解

    解决MySQl查询不区分大小写的方法讲解

    今天小编就为大家分享一篇关于解决MySQl查询不区分大小写的方法讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起...

    Veir_dev5592019-06-25
  • MysqlMySQL数据库varchar的限制规则说明

    MySQL数据库varchar的限制规则说明

    本文我们主要介绍了MySQL数据库中varchar的限制规则,并以一个实际的例子对限制规则进行了说明,希望能够对您有所帮助。 ...

    mysql技术网4192019-11-23
  • Mysql浅谈mysql 树形结构表设计与优化

    浅谈mysql 树形结构表设计与优化

    在诸多的管理类,办公类等系统中,树形结构展示随处可见,本文主要介绍了mysql 树形结构表设计与优化,具有一定的参考价值,感兴趣的小伙伴们可以参...

    小码农叔叔5242021-11-16