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

所属分类: 数据库 / Mysql 阅读数: 678
收藏 0 赞 0 分享

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

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

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;

二、检索json列的字段

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

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

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

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

三、处理json的一些函数

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

select id, JSON_PRETTY(json) from json_test\G;

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

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

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是否存在

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

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

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] ...) 插入或更新数据并返回结果

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] ...) 插入数据并返回结果,但不替换现有值。

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

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

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

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

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

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

select JSON_REMOVE(json, '$[0].name') from json_test;

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

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

select JSON_KEYS(json, '$[0]') from json_test;

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

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

select JSON_LENGTH(json, '$[0]') from json_test;

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

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

select JSON_EXTRACT(json, '$[0]') from json_test;
select JSON_EXTRACT(json, '$[0].name') from json_test;

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

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

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

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

select JSON_OBJECT('name', 'xiaoxu', 'age', 28, 'height', 1.72);

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

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

select JSON_MERGE_PATCH('{"name":"test1"}', '{"name":"test2"}');

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

select JSON_MERGE_PRESERVE('{"name":"test1"}', '{"name":"test2"}');

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

select JSON_QUOTE('你好"世界"');

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

select JSON_UNQUOTE('你好\\t\"世界\"');

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总

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

更多精彩内容其他人还在看

简单了解标准SQL的update语句三种用法

这篇文章主要介绍了简单了解标准SQL的update语句三种用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL5.7.23解压版安装教程图文详解

这篇文章主要介绍了MySQL5.7.23解压版安装教程图文详解,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

python 连接数据库mysql解压版安装配置及遇到问题

今天学习python连接数据库,就想安装一下mysql数据库,没想到小小的数据库也遇到了不少挫折,所以我就把自己的安装过程以及问题写出来分享给大家,需要的朋友可以参考下
收藏 0 赞 0 分享

为什么说MySQL单表数据不要超过500万行

在本篇文章里小编给大家整理了一篇关于为什么说MySQL单表数据不要超过500万行的相关内容,有兴趣的朋友们阅读下吧。
收藏 0 赞 0 分享

基于python的mysql复制工具详解

python-mysql-replication 是基于python实现的 MySQL复制协议工具,我们可以用它来解析binlog 获取日志的insert,update,delete等事件 ,并基于此做其他业务需求。这篇文章主要介绍了基于python的mysql复制工具,需要的朋
收藏 0 赞 0 分享

mysql语句查询用户权限过程详解

这篇文章主要介绍了mysql语句查询用户权限过程详解,授予用户的权限可能分全局层级权限、数据库层级权限、表层级别权限、列层级别权限、子程序层级权限。,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL创建数据表并建立主外键关系详解

这篇文章主要介绍了MySQL创建数据表并建立主外键关系详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL表中添加时间戳的几种方法

这篇文章主要介绍了MySQL表中添加时间戳的几种方法,有张表的数据需要用同步工具同步至其他库,需要 update_time 时间戳字段 来做增量同步,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL如何实现负载均衡功能

这篇文章主要介绍了MySQL如何实现负载均衡功能,学习过数据库的朋友们都会知道MySQL,那么如何在MySQL下实现负载均衡功能呢?本文就将为大家细致地介绍一下
收藏 0 赞 0 分享

mysql server 5.5连接不上的解决方法

这篇文章主要为大家详细介绍了mysql server 5.5连接不上的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享
查看更多