码迷,mamicode.com
首页 > 数据库 > 详细

MySQL5.7 虚拟列实现表达式或函数索引

时间:2017-07-19 14:04:44      阅读:190      评论:0      收藏:0      [点我收藏+]

标签:表达   需要   pos   虚拟   http   exp   inno   5.7   语句   

MySQL5.7 虚拟列实现表达式或函数索引

http://www.linuxidc.com/Linux/2015-11/125162.htm

 

可以用来做函数索引,也可称为表达式索引,也就是基于字段以特定函数(表达式)建立索引来提升查询性能之需。函数索引的优势在于更加精确的获取所需要的数据。

CREATE TABLE t1 (
id INT PRIMARY KEY ,
rank INT,
log_time DATETIME,
nickname VARCHAR (64),
log_date DATE AS (DATE(log_Time)) stored
) ENGINE INNODB ;

ALTER TABLE t1 ADD KEY idx_log_date(log_date);

 

或者

CREATE TABLE t1 (
id INT PRIMARY KEY ,
rank INT,
log_time DATETIME,
nickname VARCHAR (64)
) ENGINE INNODB ;
ALTER TABLE t1 ADD COLUMN log_date DATE AS (DATE(log_Time)) stored;
ALTER TABLE t1 ADD KEY idx_log_date(log_date);

 

这样,增加了一新列,用来存放date(log_time)这个表达式,并且给他加了一列索引。

那么,之前的语句就变成如下:

mysql> SELECT * FROM t1 WHERE log_date = 2015-04-09\G
*************************** 1. row ***************************
id: 95
rank: 24
log_time: 2015-04-09 05:53:13
nickname: test
log_date: 2015-04-09
*************************** 2. row ***************************
id: 3423
rank: 42
log_time: 2015-04-09 02:55:38
nickname: test
log_date: 2015-04-09
2 rows in set (0.00 sec)

 

执行后结果集和之前的一致。

 

我们来看看查询计划,发现很好的利用了 idx_log_date 索引列。

mysql> explain SELECT * FROM t1 WHERE log_date = 2015-04-09\G
*************************** 1. row ***************************
id: 1
select_type: SIMPLE
table: t1
partitions: NULL
type: ref
possible_keys: idx_log_date
key: idx_log_date
key_len: 4
ref: const
rows: 2
filtered: 100.00
Extra: NULL
1 row in set, 1 warning (0.00 sec)

 

 

利用到idx_log_date 索引

MySQL5.7 虚拟列实现表达式或函数索引

标签:表达   需要   pos   虚拟   http   exp   inno   5.7   语句   

原文地址:http://www.cnblogs.com/MYSQLZOUQI/p/7205066.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!