首页 > 代码库 > MySQL5.7 虚拟列实现表达式或函数索引
MySQL5.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: 95rank: 24log_time: 2015-04-09 05:53:13nickname: testlog_date: 2015-04-09*************************** 2. row ***************************id: 3423rank: 42log_time: 2015-04-09 02:55:38nickname: testlog_date: 2015-04-092 rows in set (0.00 sec)
执行后结果集和之前的一致。
我们来看看查询计划,发现很好的利用了 idx_log_date 索引列。
mysql> explain SELECT * FROM t1 WHERE log_date = ‘2015-04-09‘\G*************************** 1. row ***************************id: 1select_type: SIMPLEtable: t1partitions: NULLtype: refpossible_keys: idx_log_datekey: idx_log_datekey_len: 4ref: constrows: 2filtered: 100.00Extra: NULL1 row in set, 1 warning (0.00 sec)
利用到idx_log_date 索引
MySQL5.7 虚拟列实现表达式或函数索引
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。