美文网首页
MySQL索引(一)

MySQL索引(一)

作者: IT的咸鱼 | 来源:发表于2018-07-26 19:41 被阅读0次

    索引的本质

    索引(Index)是帮助MySQL高效获取数据的数据结构。提取句子主干,就可以得到索引的本质:索引是数据结构

    数据库查询是数据库的最主要功能之一。我们都希望查询数据的速度能尽可能的快,因此数据库系统的设计者会从查询算法的角度进行优化。最基本的查询算法当然是顺序查找(linear search),这种复杂度为O(n)的算法在数据量很大时显然是糟糕的,好在计算机科学的发展提供了很多更优秀的查找算法,例如二分查找(binary search)、二叉树查找(binary tree search)等

     索引的存储分类

    索引是在MYSQL的存储引擎层中实现的,而不是在服务层实现的。所以每种存储引擎的索引都不一定完全相同,也不是所有的存储引擎都支持所有的索引类型。MYSQL目前提供了一下4种索引。

    B-Tree 索引:最常见的索引类型,大部分引擎都支持B树索引。

    HASH 索引:只有Memory引擎支持,使用场景简单。

    R-Tree 索引(空间索引):空间索引是MyISAM的一种特殊索引类型,主要用于地理空间数据类型。

    Full-text (全文索引):全文索引也是MyISAM的一种特殊索引类型,主要用于全文索引,InnoDB从MYSQL5.6版本提供对全文索引的支持

    B-TREE索引类型

    普通索引

    这是最基本的索引类型,而且它没有唯一性之类的限制。普通索引可以通过以下几种方式创建:

    (1)创建索引: CREATE INDEX 索引名 ON 表名(列名1,列名 2,...);

    (2)修改表: ALTER TABLE 表名ADD INDEX 索引名 (列名1, 列名2,...);

    (3)创建表时指定索引:CREATE TABLE 表名 ( [...], INDEX 索引名 (列名1,列名 2,...) );

    UNIQUE索引

    表示唯一的,不允许重复的索引,如果该字段信息保证不会重复例如身份证号用作索引时,可设置为unique:

    (1)创建索引:CREATE UNIQUE INDEX 索引名 ON 表名(列的列表);

    (2)修改表:ALTER TABLE 表名ADD UNIQUE 索引名 (列的列表);

    (3)创建表时指定索引:CREATE TABLE 表名( [...], UNIQUE 索引名 (列的列表) );

    主键:PRIMARY KEY索引

    主键是一种唯一性索引,但它必须指定为“PRIMARY KEY”。

    (1)主键一般在创建表的时候指定:“CREATE TABLE 表名( [...], PRIMARY KEY (列的列表) ); ”。

    (2)但是,我们也可以通过修改表的方式加入主键:“ALTER TABLE 表名ADD PRIMARY KEY (列的列表); ”。

    每个表只能有一个主键。 (主键相当于聚合索引,是查找最快的索引)

    注:不能用CREATE INDEX语句创建PRIMARY KEY索引

    查看索引

    show index from tblname;

    show keys from tblname;

    Table:表的名称

    Non_unique:如果索引不能包括重复词,则为0。如果可以,则为1

    Key_name:索引的名称

    Seq_in_index:索引中的列序列号,从1开始

    Column_name:列名称

    Collation:列以什么方式存储在索引中。在MySQL中,有值‘A’(升序)或NULL(无分类)

    Cardinality:索引中唯一值的数目的估计值。通过运行ANALYZE TABLE或myisamchk -a可以更新。基数根据被存储为整数的统计数据来计数,所以即使对于小型表,该值也没有必要是精确的。基数越大,当进行联合时,MySQL使用该索引的机会就越大。

    Sub_part:如果列只是被部分地编入索引,则为被编入索引的字符的数目。如果整列被编入索引,则为NULL。

    Packed:指示关键字如何被压缩。如果没有被压缩,则为NULL。

    Null:如果列含有NULL,则含有YES。如果没有,则该列含有NO。

    Index_type:用过的索引方法(BTREE, FULLTEXT, HASH, RTREE)。

    Comment:更多评注

    相关文章

      网友评论

          本文标题:MySQL索引(一)

          本文链接:https://www.haomeiwen.com/subject/odcimftx.html