MySQL 5.7的原生JSON数据类型使用

MySQL 5.7的原生JSON数据类型使用

大家好,又见面了,我是全栈君。

新增测试用表:

CREATE TABLE lnmp (
    `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
    `category` JSON,
    `tags` JSON,
    PRIMARY KEY (`id`)
);

新增数据

INSERT INTO `lnmp` (category, tags) VALUES ('{"id": 1, "name": "lnmp.cn"}', '[1, 2, 3]');

INSERT INTO `lnmp` (category, tags) VALUES (JSON_OBJECT("id", 2, "name", "php.net"), JSON_ARRAY(1, 3, 5));

分别是两种不同的方式新增

查询:

显示json格式内部字段:

SELECT id, category->'$.id', category->'$.name', tags->'$[0]', tags->'$[2]' FROM lnmp;

去除掉默认双引号:

SELECT id, category->'$.name', JSON_UNQUOTE(category->'$.name'), category->>'$.name' FROM lnmp;

 

条件查询:

SELECT * FROM lnmp WHERE category = CAST('{"id": 1, "name": "lnmp.cn"}' as JSON);

必须使用cast转换为json类型

如果不转换就相当于查询String,是查询不到数据的。

使用json内属性进行条件查询:

SELECT * FROM lnmp WHERE category->'$.name' = 'lnmp.cn';

SELECT * FROM lnmp WHERE category->>'$.name' = 'lnmp.cn';

两种皆可

要特别注意的是,JSON 中的元素搜索是严格区分变量类型的,比如说整型和字符串是严格区分的

SELECT * FROM lnmp WHERE category->'$.id' = 1;

除了用 column->path 的形式搜索,还可以用JSON_CONTAINS 函数,但和 column->path 的形式有点相反的是,JSON_CONTAINS 第二个参数是不接受整数的,无论 json 元素是整型还是字符串,否则会出现这个错误

SELECT * FROM lnmp WHERE JSON_CONTAINS(category, '1', '$.id');

对于数组类型的 JSON 的查询,比如说 tags 中包含有 2 的数据,同样要用 JSON_CONTAINS 函数,同样第二个参数也需要是字符串

SELECT * FROM lnmp WHERE JSON_CONTAINS(tags, '2');

更新JSON:

UPDATE lnmp SET tags = '[1, 3, 4]' WHERE id = 1;

但如果要更新 JSON 下的元素,MySQL 并不支持 column->path 的形式

则可能要用到以下几个函数

JSON_INSERT() 插入新值,但不会覆盖已经存在的值

UPDATE lnmp SET category = JSON_INSERT(category, '$.name', 'lnmp', '$.url', 'www.lnmp.cn') WHERE id = 1;

可以看到 name 没有被修改,但新元素 url 已经添加进去

JSON_SET() 插入新值,并覆盖已经存在的值

UPDATE lnmp SET category = JSON_SET(category, '$.host', 'www.lnmp.cn', '$.url', 'http://www.lnmp.cn') WHERE id = 1;

可以看到 host 已经插入,url 已经被修改

JSON_REPLACE() 只替换存在的值

UPDATE lnmp SET category = JSON_REPLACE(category, '$.name', 'php', '$.url', 'http://www.php.net') WHERE id = 2;

可以看到 name 已经被替换,url 不存在被忽略。

JSON_REMOVE() 删除 JSON 元素

UPDATE lnmp SET category = JSON_REMOVE(category, '$.url', '$.host') WHERE id = 1;

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111614.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月18日 上午7:00
下一篇 2022年2月18日 上午7:00


相关推荐

  • vue父子组件传值props_vue子组件调用父组件的方法并传参

    vue父子组件传值props_vue子组件调用父组件的方法并传参vue页面结构在做项目的时候常常有这样的一个情况,这个页面的数据(比如:id号)要带到另一个页面去查询某个数据的详情等,传统的做法不是在url上加参数,cookie或者是现在H5的“sessionStorage”和“localStorage”上赋值,这是页面之间传递的方法。随着Angularjs,React,Vue的流行组件式的开发方式成为另一种不错的解决方案。最近就有一些小伙伴问我,vue组件之间是如何传递参数的?其实vue是有三种方式可以组件之间传递数据(props,组件通信,slot)..

    2025年6月24日
    5
  • 数据结构–链表的排序详解

    数据结构–链表的排序详解1、前言前面两篇博客,我已经把线性表的两种基本的表示形式,做了一个基本的介绍和一些对比。但是,我突然发现在链表这里我缺少一个很重要的内容,那就是对我们的链表进行排序,其实,在连接两个链表的时候,就要求我们的那两个链表是有序的。2、链表排序—最简单、直接的方式(直接采用冒泡或者选择排序,而且不是交换结点,只交换数据域)//线性表的排序,采用冒泡排序,直接遍历链表voidListsort(Nod

    2022年10月11日
    4
  • 线程创建的四种方式

    线程创建的四种方式java中创建线程的四种方法以及区别Java使用Thread类代表线程,所有的线程对象都必须是Thread类或其子类的实例。Java可以用四种方式来创建线程,如下所示:1)继承Thread类创建线程2)实现Runnable接口创建线程3)使用Callable和Future创建线程4)使用线程池例如用Executor框架下面让我们分别来看看这四种创建线程的方法。–…

    2022年5月3日
    72
  • 测试中常用的adb shell命令

    测试中常用的adb shell命令

    2021年5月23日
    138
  • 工具使用 – office快捷键

    工具使用 – office快捷键看一遍 记住最常用的 有利于提高文档编写效率

    2026年3月18日
    2
  • 通过企业微信服务端API接口进行群发应用消息

    通过企业微信服务端API接口进行群发应用消息通过企业微信服务端 API 接口进行群发应用消息一 基本术语介绍说明 1 corpid2 userid3 部门 id4 tagid 最近项目上需要用到企业微信应用进行消息的群发功能 用来将系统产生的告警消息通过企业微信群发的方式通知客户方 来达到及时处理故障的目的 使用了下还是较简单的 这里记录一下过程 备查 一 基本术语介绍说明 1 corpid 每个企业都拥有唯一的 corpid 获取此信息可在管理后台 我的企业 企业信息 下查看 企业 ID 需要有管理员权限 2 userid 每个成员都有唯一

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号