zoukankan      html  css  js  c++  java
  • MySQL InnoDB表和索引之聚簇索引与第二索引

    MySQL InnoDB表和索引之聚簇索引与第二索引

    By:授客QQ:1033553122

     

    每个InnoDB表都有一个称之为聚簇索引(clustered index)的特殊索引,存储记录行数据。通常,聚簇索引和主索引是近义的。

     

    l   当在表上定义一个主键时, InnoDB把它当聚簇索引用。为每个表都定义一个主键,如果没有逻辑上唯一且NOT-NULL的列,则添加一个自动增长(auto-increment)的列

     

    l   如果没为表定义主键,mysql定位所有索引列都为NOT NULL的第一个唯一索引,并把它当聚簇索引使用。

     

    l   如果表没有主键或合适的唯一索引,InnoDB会在某个包含row ID值的合成列上生成一个隐藏的聚簇索引。记录行按表中InnoDB赋予行的row ID排序。row ID为一6字节域,当有新行被插入时会自动增加,所以,按row ID排序的行物理上为按插入顺序排序。

     

     

    二级索引(secondary index)和聚簇索引的关系

    除了聚簇索引外的索引,都叫二级索引。InnoDB中,每个二级索引条目都包含主键列InnoDB使用主键值来搜索聚簇索引中的记录。

    eg:

    CREATE TABLE tb_name (

      col1 INT NOT NULL,

      col2 INT NOT NULL,

      col3 INT

      PRIMARY KEY (col1, col2),

      INDEX index_name(col3)

    ) ENGINE = InnoDB;

     

    如上,二级索引index_namecol3)的元组在InnoDB内部实际被扩展成(col3, col2, col3),即包含主键值.

     

    参考连接:

    http://dev.mysql.com/doc/refman/5.5/en/innodb-index-types.html

     

  • 相关阅读:
    从头学pytorch(二十一):全连接网络dense net
    Linux环境实现python远程可视编程
    centos7安装Anaconda3
    sql语句中包含引号处理方法
    syslog 日志
    python 判断是否为中文
    numpy简介
    django之模板显示静态文件
    Linux(Ubuntu)安装libpcap
    Bug预防体系
  • 原文地址:https://www.cnblogs.com/shouke/p/10157724.html
Copyright © 2011-2022 走看看