简单谈谈MySQL5.7 JSON格式检索

作者:yangfei001 时间:2024-01-22 09:07:03 

MySQL5.7版本开始支持JSON格式,在创建表时,可以指定列表的数据类型为JSON,但是如何在JSON格式上创建索引呢??

本人做了一个简单测试。

第一步:建立一个包含JSON类型的表:


CREATE TABLE json_test` (
id` int (8) NOT NULL AUTO_INCREMENT,
content` json NOT NULL ,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

第二步:初始化数据


insert into json_test(content) value( '{"name":"zhangsan","age":18}' );
insert into json_test(content) value( '{"name":"lisi","age":19}' );
insert into json_test(content) value( '{"name":"wangwu","age":20}' );

第三步:查询JSON类列的数据

select json_extract(content,  '$.name' )  from json_test  where json_extract(content,  '$.name' )= "zhangsan" ;

通过expain分析改查询语句,发现其走全表扫描

简单谈谈MySQL5.7 JSON格式检索

在网上查询资料,得知如果要在JSON列上进行检索,需要对检索的key创建虚拟列,然后再虚拟列上创建索引

第四步:在content列上,对"name"建立虚拟列

ALTER TABLE json_test  ADD name_virtual  varchar (32) GENERATED ALWAYS  AS (json_extract(content,  '$.name' )) VIRTUAL;

第五步:对虚拟列创建索引

CREATE INDEX name_virtual_index  ON json_test(name_virtual);

再次做查询( 注,where条件需要使用虚拟列来进行检索,如果直接用JSON列比较,还是会走全表扫描 )

explain  select json_extract(content,  '$.name' )  from json_test  where name_virtual= "zhangsan" \G

简单谈谈MySQL5.7 JSON格式检索

总结:

其实MySQL通过一种空间换时间的做法,类似创建一个触发器,把JSON列上的数据冗余存储到虚拟列上,比较的时候通过走虚拟列的索引,再定位到实际数据。

标签:MySQL,MySQL5.7,JSON
0
投稿

猜你喜欢

  • Python 实现数据结构-堆栈和队列的操作方法

    2021-05-25 20:56:16
  • Python 模拟员工信息数据库操作的实例

    2024-01-20 03:42:04
  • 安全地关闭MySQL服务的教程

    2024-01-16 23:50:13
  • python可以美化表格数据输出结果的两个工具

    2022-06-05 02:33:32
  • Django自定义全局403、404、500错误页面的示例代码

    2021-07-27 20:03:33
  • Python中url标签使用知识点总结

    2022-05-12 11:13:09
  • Python机器学习之KNN近邻算法

    2022-05-12 23:14:17
  • 自然描述与自然任务

    2010-01-26 15:51:00
  • Numpy 理解ndarray对象的示例代码

    2023-07-17 00:56:20
  • oracle中添加删除主键的方法

    2023-06-30 00:28:52
  • vue element-ul实现展开和收起功能的实例代码

    2024-05-29 22:48:16
  • python离散建模之感知器学习算法

    2022-06-10 04:49:47
  • Javascript类型系统之undefined和null浅析

    2024-04-16 09:32:46
  • 菜鸟大讲堂:如何查看mysql版本的四种方法

    2009-09-05 09:54:00
  • element 实现导航栏收起展开功能及思路

    2024-05-10 14:17:11
  • JavaScript中call,apply,bind的区别与实现

    2024-04-22 12:51:26
  • 详解python string类型 bytes类型 bytearray类型

    2023-09-22 20:47:18
  • JS 中如何判断 null

    2007-12-13 20:28:00
  • Python通用验证码识别OCR库之ddddocr验证码识别

    2021-05-16 22:55:00
  • Python 代码实现各种酷炫功能

    2022-12-24 10:40:16
  • asp之家 网络编程 m.aspxhome.com