一:索引的引入
索引定义:索引是由数据库表中一列或者多列组合而成,其作用是提高对表中数据的查询速度。
类似于图书的目录,方便快速定位,寻找指定的内容,如一本1000页的书,如果没有目录,你想要知道指定的内容,必须要1页1页翻过去,是不是很浪费时间?
二:索引的优缺点
优点:提高查询数据的速度。
缺点:创建和维护索引的时间增加了。
三: 索引实际应用
t_teacher表中有100000条数据,是我利用hibernate插的,大家可以自己用jdbc插一下或者用后面的知识创建一个存储过程来插,感兴趣的可以先百度预习下。
mysql>select count(*) from t_teacher;
mysql>select * from t_teacher where name=’老师99999’; #我这的速度是79毫秒,这边用name不能用id,因为id是主键
mysql>create index `index_name` on `t_teacher`(`name`);#在name列上创建索引
mysql>select * from t_teacher where name=’老师99999’;#再次查找,速度几乎是0毫秒,可见加了索引的速度是多么的快.
四:索引分类
1: 普通索引(常用)
这类索引可以创建在任何数据类型中。
2: 唯一性索引(常用)
使用unique 参数可以设置,在创建唯一性索引时,限制该索引的值必须是唯一的,主键默认就是唯一的。
3: 全文索引
使用fulltext 参数可以设置,全文索引只能创建在char,varchar,text 类型的字段上。主要作用就是提高查询较大字符串类型的速度;只有myisam 引擎支持该索引,mysql 默认引擎不支持。
4: 单列索引
在表中可以给单个字段创建索引,单列索引可以是普通索引,也可以是唯一性索引,还可以是全文索引。
5: 多列索引
多列索引是在表的多个字段上创建一个索引。
6: 空间索引
使用spatial 参数可以设置空间索引。空间索引只能建立在空间数据类型上,这样可以提高系统获取空间数据的效率;只有myisam 引擎支持该索引,mysql 默认引擎不支持。
五:创建索引
5.1 创建表的时候创建索引
create table 表名(属性名数据类型[完整性约束条件],
属性名数据类型[完整性约束条件],
....
属性名数据类型
[unique | fulltext | spatial ] index| key
[别名] (属性名1 [(长度)] [asc | desc])
);
这边没有指定索引的名字,使用mysql默认的索引名
5.2 在已经存在的表上创建索引
create [ unique | fulltext | spatial ] index 索引名
on 表名(属性名[(长度)] [ asc | desc]);
mysql>create table `t_test2`(
id int primary key auto_increment,
username varchar(30),
password varchar(10)
);
mysql>create index `index_username` on `t_test2`(`username`);
5.3 用alter table 语句来创建索引
alter table 表名add [ unique | fulltext | spatial ] index
索引名(属性名[(长度)] [ asc | desc]);
mysql>alter table `t_test2`
add unique index `index_password`(`password`);
六: 删除索引
drop index 索引名on 表名;
mysql>drop index `index_username` on `t_test2`;
七: 总结
今天为大家带来了索引的相关内容,大家好好练习消化下,下节为大家带来视图的相关内容,谢谢大家!
