mysql的索引详解

  1. 什么是索引:

索引即数据库通过一定的组织方式(B-tree等)把创建索引列上数值和位置存储已达到快速查询的目的。

  1. 索引的种类:

(1)         主键索引,一张表指定主键,自动创建索引。

(2)         唯一性索引,列值不能相同,但相对于主键索引可以为空。

(3)         FULLTEXT 是全文索引,用于搜索长文本.

(4)         普通索引 没有以上限制

有个别人举得很好的例子:

这个系统有一个会员表
有下列字段:
会员编号   INT
会员姓名   VARCHAR(10)
会员身份证号码   VARCHAR(18)
会员电话   VARCHAR(10)
会员住址   VARCHAR(50)
会员备注信息  TEXT

那么这个 会员编号,作为主键,使用 PRIMARY
会员姓名 如果要建索引的话,那么就是普通的 INDEX
会员身份证号码   如果要建索引的话,那么可以选择 UNIQUE (唯一的,不允许重复)
会员备注信息 , 如果需要建索引的话,可以选择 FULLTEXT,全文搜索。

不过
FULLTEXT 用于在长文本建立索引效果最好,用在比较短的文本,普通的 INDEX 就可以了。

  1. 索引的建立、删除、查看

mysql>
desc card_info;

+--------+-------------+------+-----+---------+-------+

|
Field  | Type        | Null | Key | Default | Extra |

+--------+-------------+------+-----+---------+-------+

| number
| int(8)      | NO   | PRI | NULL    |      
|

|
name   | varchar(10) | NO   |    
| NULL    |       |

|
phone  | int(11)     | YES 
|     | NULL    |      
|

| id     | int(18)     | NO  
| UNI | NULL    |       |

|
info   | text        | YES 
|     | NULL    |      
|

+--------+-------------+------+-----+---------+-------+

1.  主键索引指定主键时,已经默认创建,id也会产生一个unique索引

mysql>
show index from card_info;

+-----------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

|
Table     | Non_unique | Key_name |
Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null
| Index_type | Comment | Index_comment |

+-----------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

|
card_info |          0 | PRIMARY  |           
1 | number      | A         |           0 |     NULL | NULL   |     
| BTREE      |         |               |

|
card_info |          0 | id       |            1 | id          | A        
|           0 |     NULL | NULL   | YES 
| BTREE      |         |               |

+-----------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

2 rows in set (0.00 sec)

2.  创建一个普通索引

create index index_name on card_info(name);

mysql> show index from
card_info;

+-----------+------------+------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

|
Table     | Non_unique | Key_name   | Seq_in_index | Column_name | Collation |
Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |

+-----------+------------+------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

|
card_info |          0 | PRIMARY    |           
1 | number      | A         |           0 |     NULL | NULL   |     
| BTREE      |         |               |

|
card_info |          0 | id         |            1 | id          | A        
|           0 |     NULL | NULL   | YES 
| BTREE      |         |               |

|
card_info |          1 | index_name
|            1 | name        | A         |           0 |     NULL | NULL   |     
| BTREE      |         |               |

+-----------+------------+------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

3 rows in set (0.00 sec)

3.  创建fulltext索引

alter table card_info add fulltext index index_info(info)

4.  删除索引

5.  mysql> alter table card_info drop index index_name;

6.  创建联合索引

create index name_phone on card_info(name,phone);

  1. 索引的选择与注意事项
  2. 创建索引
    对于查询占主要的应用来说,索引显得尤为重要。很多时候性能问题很简单的就是因为我们忘了添加索引而造成的,或者说没有添加更为有效的索引导致。如果不加索引的话,那么查找任何哪怕只是一条特定的数据都会进行一次全表扫描,如果一张表的数据量很大而符合条件的结果又很少,那么不加索引会引起致命的性能下 降。但是也不是什么情况都非得建索引不可,比如性别可能就只有两个值,建索引不仅没什么优势,还会影响到更新速度,这被称为过度索引。
  3. 复合索引
    比如有一条语句是这样的:select
    * from users where area=’beijing’ and age=22;
    如果我们是在area和age上分别创建单个索引的话,由于mysql查询每次只能使用一个索引,所以虽然这样已经相对不做索引时全表扫描提高了很多效 率,但是如果在area、age两列上创建复合索引的话将带来更高的效率。如果我们创建了(area,
    age, salary)的复合索引,那么其实相当于创建了(area,age,salary)、(area,age)、(area)三个索引,这被称为最佳左前缀 特性。因此我们在创建复合索引时应该将最常用作限制条件的列放在最左边,依次递减。
  4. 索引不会包含有NULL值的列
    只要列中包含有NULL值都将不会被包含在索引中,复合索引中只要有一列含有NULL值,那么这一列对于此复合索引就是无效的。所以我们在数据库设计时不要让字段的默认值为NULL。
  5. 使用短索引
    对串列进行索引,如果可能应该指定一个前缀长度。例如,如果有一个CHAR(255)的 列,如果在前10 个或20 个字符内,多数值是惟一的,那么就不要对整个列进行索引。短索引不仅可以提高查询速度而且可以节省磁盘空间和I/O操作。
  6. 排序的索引问题
    mysql查询只使用一个索引,因此如果where子句中已经使用了索引的话,那么order
    by中的列是不会使用索引的。因此数据库默认排序可以符合要求的情况下不要使用排序操作;尽量不要包含多个列的排序,如果需要最好给这些列创建复合索引。
  7. like语句操作
    一般情况下不鼓励使用like操作,如果非使用不可,如何使用也是一个问题。like
    “%aaa%” 不会使用索引而like
    “aaa%”可以使用索引。
  8. 不要在列上进行运算
    select * from users where YEAR(adddate)<2007;将在每个行上进行运算,这将导致索引失效而进行全表扫描,因此我们可以改成select
    * from users where adddate<‘2007-01-01’;
  9. 不使用NOT
    IN
    <>操作

NOT
IN和<>操作都不会使用索引将进行全表扫描。NOT
IN可以NOT
EXISTS代替,id<>3则可使用id>3
or id<3来代替。

时间: 2024-10-24 21:07:14

mysql的索引详解的相关文章

mysql 联合索引详解

mysql 联合索引详解   联合索引又叫复合索引.对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分.例如索引是key index (a,b,c). 可以支持a | a,b| a,b,c 3种组合进行查找,但不支持 b,c进行查找 .当最左侧字段是常量引用时,索引就十分有效. 两个或更多个列上的索引被称作复合索引.利用索引中的附加列,您可以缩小搜索的范围,但使用一个具有两列的索引 不同于使用两个单独的索引.复合索引的结构与电话簿类似,人名由

mysql联合索引详解

所有的MySQL列类型能被索引.在相关的列上的使用索引是改进SELECT操作性能的最好方法. 一.前缀索引 对于CHAR和VARCHAR列,你可以索引列的前缀.这更快并且比索引整个列需要较少的磁盘空间.在CREATE TABLE语句中索引列前缀的语法看起来像这样: KEY index_name (col_name(length))下面的例子为name列的头10个字符创建一个索引: mysql> CREATE TABLE test (name CHAR(200) NOT NULL,KEY inde

MySQL数据库索引详解

一.什么是索引: 索引是一个排序的列表,在这个列表中存储着索引值和包含这个值的数据所在行的物理地址,在数据十分庞大的时候,索引可以大大加快查询速度,这是因为使用索引后可以不用全表扫描来定位某行的数据,而是先通过索引表找到该行数据对应的物理地址然后访问相应的数据. 索引通过不断缩小想要获取数据的范围来筛选出最终想要的结果,同时把随机事件变成顺序事件,也就是说,有个这个机制我们可以总是用同一种查找方式来锁定数据: 索引实际就是一张表,该表保存了主键和索引字段,并指向实体表的记录,所以索引也是占了一大

MySQL 数据库索引详解

什么是索引 索引是对 数据库中一列或者多列的值进行排序的一中结构,使用索引可以快速访问数据库中表的特定信息.索引的一个主要的目的就是加快检索表中数据,亦即能协助信息搜索者尽快的找到符合限制条件的记录的辅助数据结构. 简单来说索引就是数据库的目录. 索引有什么作用 索引的最大作用就是加快数据库的查询速度. 索引为什么会加快查询速度 数据库在执行一条SQL语句的时候,默认的方式是根据搜索条件进行全表扫描,遇到匹配条件的就加入搜索结果集合.但若是遇到大数据量的查询时,直接全表匹配的方式太慢了,这时候就

MySQL之索引详解

这篇博客将要阐述为什么使用b+树作为索引,而不是b树或者其他树 1.什么是b树 (图片来自网络) b树相关特性:⑴关键字分布在整棵树中 ⑵任何一个关键字只出现在一个节点上 ⑶搜索可能在非叶子节点上结束 ⑷搜索性能等价于在关键字全集内做二分查找 2.什么是b+树 (图片来自网络) b+树相关特性:⑴非叶子节点的子树指针与关键字个数相同 ⑵b+树只有在到达叶子节点才会命中,其性能也等价于在关键字全集做二分查找 ⑶所有关键字都出现在叶子节点的链表中,且链表中关键字恰好有序 ⑷不可能在非叶子节点命中 ⑸

mysql索引详解,摘自《MySQL 5权威指南》

本文介绍了数据库索引,及其优.缺点.针对MySQL索引的特点.应用进行了详细的描述.分析了如何避免MySQL无法使用,如何使用EXPLAIN分析查询语句,如何优化MySQL索引的应用.本文摘自<MySQL 5权威指南>(3rd)的8.9节.(2007.07.05最后更新)        索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针.注:[1]索引不是万能的!索引可以加快数据检索操作,但会使数据修改操作变慢.每修改数据记录,索引

mysql 索引 详解

索引是快速搜索的关键.MySQL索引的建立对于MySQL的高效运行是很重要的.下面介绍几种常见的MySQL索引类型. 在数据库表中,对字段建立索引可以大大提高查询速度.假如我们创建了一个 mytable表: CREATE TABLE mytable(   ID INT NOT NULL,    username VARCHAR(16) NOT NULL  );   我们随机向里面插入了10000条记录,其中有一条:5555, admin. 在查找username="admin"的记录

MySQL配置文件mysql.ini参数详解、MySQL性能优化

MySQL配置文件mysql.ini参数详解.MySQL性能优化 my.ini(Linux系统下是my.cnf),当mysql服务器启动时它会读取这个文件,设置相关的运行环境参数. my.ini分为两块:Client Section和Server Section.   Client Section用来配置MySQL客户端参数.   要查看配置参数可以用下面的命令: show variables like '%innodb%'; # 查看innodb相关配置参数 show status like

MySQL中EXPLAIN详解

MySQL中EXPLAIN详解 explain显示了mysql如何使用索引来处理select语句以及连接表.可以帮助选择更好的索引和写出更优化的查询语句. 使用方法,在select语句前加上explain就可以了: 如:explain select username,first_name form hx,itlearner where a.id=b.id EXPLAIN列的解释: id:本次 select 的标识符.在查询中每个 select都有一个顺序的数值. select_type :查询类