zoukankan      html  css  js  c++  java
  • MySQL5.7 虚拟列实现表达式或函数索引

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

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


    https://dev.mysql.com/doc/refman/5.7/en/create-table-generated-columns.html
    语法
    col_name data_type [GENERATED ALWAYS] AS (expression)
      [VIRTUAL | STORED] [UNIQUE [KEY]] [COMMENT comment]
      [[NOT] NULL] [[PRIMARY] KEY]
     
    [GENERATED ALWAYS]:非必须
    VIRTUAL:计算列只不会存储,建议在计算列上加索引
    STORED:计算列值会被存储,建议在计算列上加索引

    [UNIQUE [KEY]] [COMMENT comment]  [[NOT] NULL] [[PRIMARY] KEY] 这些属性跟普通列属性一样,但是区别在于的顺序不能随意掉乱
    比如[UNIQUE [KEY]]不能放在[COMMENT comment]之后,一定要按照[UNIQUE [KEY]] [COMMENT comment]  [[NOT] NULL] [[PRIMARY] KEY]


    一张表里可以存在VIRTUAL类型计算列,也可以存在STORED类型计算列
    一个表里的计算列可以引用同一个表里的另一个计算列
    计算列不能使用 AUTO_INCREMENT 计算列表达式里也不能使用有 AUTO_INCREMENT的普通列
    CREATE TABLE ... LIKE和CREATE TABLE ... SELECT都不允许导入计算列
    表分区支持计算列
    对于INSERT, REPLACE,  UPDATE,replaced, 计算列那列只能用default这个值,当然不指定显式插入计算列也是可以的
    insert into tt(id,mod_id) values(22,default);

    insert into t13(id,log_time,log_date)  values(4,'2017-3-23',default);
    Query OK, 1 row affected (0.02 sec)

    insert into t13(id,log_time)  values(5,'2017-5-23');
    Query OK, 1 row affected (0.02 sec)

    select * from t13;
    +----+---------------------+------------+
    | id | log_time            | log_date   |
    +----+---------------------+------------+
    |  1 | 2017-02-13 00:00:00 | 2017-02-13 |
    |  2 | 2017-02-13 00:00:00 | 2017-02-13 |
    |  4 | 2017-03-23 00:00:00 | 2017-03-23 |
    |  5 | 2017-05-23 00:00:00 | 2017-05-23 |
    +----+---------------------+------------+



    CREATE TABLE t11 (
    id INT PRIMARY KEY ,
    log_time DATETIME,
    log_date DATE AS (DATE(log_Time)) stored
    ) ENGINE INNODB ;

    ALTER TABLE t1 ADD KEY idx_log_date(log_date);




    CREATE TABLE t12 (
    id INT PRIMARY KEY ,
    log_time DATETIME,
    log_date DATE  AS (DATE(log_Time)) VIRTUAL
    ) 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),
    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 索引

  • 相关阅读:
    mysql数据库的test类型
    jvm虚拟机分享课笔记
    内存模型中没有gc的是哪个
    jvm内存模型中-栈,方法区,程序计数器是线程安全的
    Random.nextInt()替换Math.random()
    异常抛出注意点
    缓存好文章
    java 实现serialVersionUID
    什么叫反向代理什么叫正向代理
    mysql count与sum的区别
  • 原文地址:https://www.cnblogs.com/MYSQLZOUQI/p/7205066.html
Copyright © 2011-2022 走看看