再谈MySQL JSON数据类型

本文首发于个人微信公众号《andyqian》,期待你的关注~
前言

  眨眼间,有一小段时间没有更新文章了。惰性属性又增。你是否还记得,之前写过的《说说 MySQL JSON 数据类型》这篇文章,在这篇文章中,我们简单的介绍了MySQL JSON函数。但是在实际操作中。还有更多的实用操作没有介绍。如: JSON字符串如何搜索?如何获取JSON字符串中特定的属性?能不能批量替换JSON中特定key?等等。别急,我们就在下面给出答案。

数据准备

  数据如下所示:

create table t_base_data(   
    id bigint(20) not null primary key auto_increment comment "主键",
    content json null comment "内容",
    created_at datetime null comment "创建时间",
    updated_at datetime null comment "修改时间"
) engine=innodb charset=utf8

-- 初始化数据:
INSERT INTO `andyqian`.`t_base_data` (`id`, `content`, `created_at`, `updated_at`) VALUES ('1', '{\"blog\": \"www.andyqian.com\", \"name\": \"andyqian\"}', NULL, '2018-04-08 11:19:44');

操作数据库版本:5.7.20

搜索

  当我们需要获取JSON字符串中的某个key值时。我们可以通过如下方式:

  1. 列名->key

如下所示:

mysql> select content->"$.blog" from t_base_data;
+--------------------+
| content->"$.blog"  |
+--------------------+
| "www.andyqian.com" |
+--------------------+
1 row in set (0.00 sec

2.列名->>key 为提供转义后的字符。
如下所示:

mysql> select content->>"$.blog" from t_base_data;
+--------------------+
| content->>"$.blog" |
+--------------------+
| www.andyqian.com   |
+--------------------+
1 row in set (0.00 sec)
  1. JSON_EXTRACT 函数

函数:JSON_EXTRA(JSON串, 操作符)。
用途: 用户提取JSON属性。

使用例子:

mysql> SELECT JSON_EXTRACT('{"blog":"www.andyqian.com","name": "andyqian"}' ,'$.blog');
+--------------------------------------------------------------------------+
| JSON_EXTRACT('{"blog":"www.andyqian.com","name": "andyqian"}' ,'$.blog') |
+--------------------------------------------------------------------------+
| "www.andyqian.com"                                                       |
+--------------------------------------------------------------------------+
1 row in set (0.00 sec)
json_insert

  在Java中,附加字符串,我们通常可以使用append()方法进行操在MySQL中,varchar数据类型,我们也可以使用concat函数进行追加。同样的,在JSON操作中,MySQL也给我们提供了对应的函数:JSON_INSERT。
使用例子如下:

mysql> set @info = '{"blog":"www.andyqian.com","name": "andyqian"}';
Query OK, 0 rows affected (0.00 sec)

mysql> select json_insert(@info,"$.email","andytohome@gmail.com");
+-----------------------------------------------------------------------------------+
| json_insert(@info,"$.email","andytohome@gmail.com")                               |
+-----------------------------------------------------------------------------------+
| {"blog": "www.andyqian.com", "name": "andyqian", "email": "andytohome@gmail.com"} |
+-----------------------------------------------------------------------------------+
1 row in set (0.01 sec)

这里需要注意的是: 如果新增的属性已存在。该属性不会被新增。

json_replace

  有了新增。在批量修改指定JSON内容的值时。替换可少不了。现在我们介绍下面这个函数json_replace函数。
使用方法如下所示:

mysql> set @info = '{"blog":"www.andyqian.com","name": "andyqian"}';
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT json_replace(@info, '$.name', "juqian");
+------------------------------------------------+
| json_replace(@info, '$.name', "juqian")        |
+------------------------------------------------+
| {"blog": "www.andyqian.com", "name": "juqian"} |
+------------------------------------------------+
1 row in set (0.00 sec)

这个语句的意思为: 我们需要替换

{"blog":"www.andyqian.com","name": "andyqian"}

中的name属性的值为juyuqian

注意: 上面我们是直接使用key的名称,来进行查找。其实。我们还可以使用角标的方式。进行查找。例如在上述语句中,我们可以将$.name修改为$[1] 也是可以的。

json_remove

  有了新增,替换,当然还少不了删除了。下面我们就介绍json_remove函数

mysql> select json_remove('{"blog":"www.andyqian.com","name": "andyqian"}' , '$.blog');
+--------------------------------------------------------------------------+
| json_remove('{"blog":"www.andyqian.com","name": "andyqian"}' , '$.blog') |
+--------------------------------------------------------------------------+
| {"name": "andyqian"}                                                     |
+--------------------------------------------------------------------------+
1 row in set (0.00 sec)

我们只需要指定,需要remove的key值即可。

最后

  如果对上面的JSON操作,觉得一下子适应不过来。我们可以看成是在Java中操作fastjson来进行JSON操作一样。就容易理解一些了。





相关阅读:

说说Java日志

说几个拖垮系统的小细节!

浅谈MySQL表结构设计

说说 MySQL JSON 数据类型


这里写图片描述
扫码关注,一起进步
个人博客:  http://www.andyqian.com

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值