MySQL5.7 虚拟列实现表达式索引
来源:互联网 发布:淘宝网买什么 编辑:程序博客网 时间:2024/06/05 00:45
MySQL自古以来就不提供函数索引这么复杂的功能。那怎么在MySQL里面实现这样的功能呢? 我们先来看看函数索引的概念。函数索引,也可称为表达式索引,也就是基于字段以特定函数(表达式)建立索引来提升查询性能之需。函数索引的优势在于更加精确的获取所需要的数据。
MySQL 5.7提供了一个新的特性,虚拟列,可以很完美的解决这个问题。
在介绍虚拟列之前,我们来看看在MySQL里面普通索引的范例。
示例表结构:
示例表数据量,这里我增加了5000条记录:
假设我们来检索2015年4月9号的数据。(结果是有两条记录,id 分别为95和3423。)
下来我们看看这条语句的查询计划。
我们发现TYPE是ALL,扫描的函数是5000,也就是说这条语句进行了一个全表扫描。 虽然给字段log_time 加了索引,但是没有用到,那这个时候怎么办?
在MySQL里面一般这样修改:
通过查询结果,发现结果集一致,那再来看看查询计划
可以看到这条修改过的语句很好的利用到了idx_log_time这条索引。
那好,这个是之前在MySQL 5.6以及之前的旧版本解决方法,随着MySQL 5.7的发布,虚拟列的出现让这个问题更加简单。
现在修改下之前的表结构:
这样,增加了一新列,用来存放date(log_time)这个表达式,并且给他加了一列索引。
那么,之前的语句就变成如下:
执行后结果集和之前的一致。
我们来看看查询计划,发现很好的利用了idx_log_date索引列。
通过以上介绍,我们看到虚拟列实现起来相对之前的方法来的容易的多。但是这里笔者还是得说上几句。
函数索引的用法以及SQL语句虽然写起来简单,但是在大部分场合下,只能说不得已而为之,是一种设计上的缺陷,后期增加了运维人员的运维难度以及繁琐度。这也就是为什么MySQL 直到5.7才推出了这项类似的功能的原因。
MySQL 5.7提供了一个新的特性,虚拟列,可以很完美的解决这个问题。
在介绍虚拟列之前,我们来看看在MySQL里面普通索引的范例。
示例表结构:
示例表数据量,这里我增加了5000条记录:
假设我们来检索2015年4月9号的数据。(结果是有两条记录,id 分别为95和3423。)
下来我们看看这条语句的查询计划。
我们发现TYPE是ALL,扫描的函数是5000,也就是说这条语句进行了一个全表扫描。 虽然给字段log_time 加了索引,但是没有用到,那这个时候怎么办?
在MySQL里面一般这样修改:
通过查询结果,发现结果集一致,那再来看看查询计划
可以看到这条修改过的语句很好的利用到了idx_log_time这条索引。
那好,这个是之前在MySQL 5.6以及之前的旧版本解决方法,随着MySQL 5.7的发布,虚拟列的出现让这个问题更加简单。
现在修改下之前的表结构:
这样,增加了一新列,用来存放date(log_time)这个表达式,并且给他加了一列索引。
那么,之前的语句就变成如下:
执行后结果集和之前的一致。
我们来看看查询计划,发现很好的利用了idx_log_date索引列。
通过以上介绍,我们看到虚拟列实现起来相对之前的方法来的容易的多。但是这里笔者还是得说上几句。
函数索引的用法以及SQL语句虽然写起来简单,但是在大部分场合下,只能说不得已而为之,是一种设计上的缺陷,后期增加了运维人员的运维难度以及繁琐度。这也就是为什么MySQL 直到5.7才推出了这项类似的功能的原因。
阅读全文
0 0
- MySQL5.7 虚拟列实现表达式索引
- MySQL5.7 虚拟列实现表达式索引
- MySQL5.7 虚拟列实现表达式索引
- 索引类型之虚拟列
- 虚拟列上的索引
- MySQL5.6 Internals-隐藏的索引列
- mysql5.7官网直译优化和索引--多列索引
- mysql5.7官网直译优化和索引--使用生成列的索引
- mysql5.7 索引
- 函数索引与虚拟列的比较
- mysql5.7在多列索引 in条件查询的优化
- proftpd+mysql5.6实现虚拟用户管理
- MySql5.7 建立全文索引
- 给含有空值的列创建虚拟索引
- mysql5.6, mysql5.7什么时候该创建索引?
- 虚拟列
- MySql5.7 全文索引(针对中文搜索)
- 虚拟索引
- nodejs做即时聊天
- mount实现windows目录与linux的目录共享
- 【iOS】为用户界面加入运动拟真效果
- 5.验证码机器识别
- mysql的主从复制与读写分离
- MySQL5.7 虚拟列实现表达式索引
- Google's BigTable 原理 (翻译)
- 斐波那契数--递归和非递归实现
- 【转载】JSP会话跟踪学习记录
- markdown中如何设置图片的显示大小
- 多线程下synchronized修饰static方法与非static方法的区别
- java中配置path和CLASSPATH的意义
- 内存中常见异常值的解释(比如0xcccccccc、0xcdcdcdcd和 0xfeeefeee 异常值 )
- 梯度下降法