索引简介
索引是对数据库表中一个或多个列(例如,employee 表的姓名 (name) 列)的值进行排序的结构。如果想按特定职员的姓来查找他或她,则与在表中搜索所有的行相比,索引有助于更快地获取信息。
例如这样一个查询:select * from table1 where id=10000。如果没有索引,必须遍历整个表,直到ID等于10000的这一行被找到为止;有了索引之后(必须是在ID这一列上建立的索引),即可在索引中查找。由于索引是经过某种算法优化过的,因而查找次数要少的多。可见,索引插叙的速度要比没有索引的速度要快很多
MySQL中常见索引有:
- 普通索引
- 唯一索引
- 主键索引
- 组合索引
下面就应用一下索引吧
索引操作
一、普通索引(index)
普通所以只有一个功能,就是加快查找速度。操作如下
1、先创建一个表
create table tab1( nid int not null auto_increment primary key, name varchar(32) not null, email varchar(64) not null, extra text, index ix_name (name) )
2、创建索引
create index 索引名称 on 表名(列名)
3、删除索引
drop 索引名称 on 表名;
4、查看索引
show index from 表名;
5、注意事项(对于创建索引时如果是BLOB 和 TEXT 类型,必须指定length。)
create index index_name on tab1(extra(32));
二、唯一索引(unique)
唯一性索引unique index和一般索引normal index最大的差异就是在索引列上增加了一层唯一约束。添加唯一性索引的数据列可以为空,但是只要存在数据值,就必须是唯一的。
1、创建表+唯一索引