索引
在关系数据库中,如果有上万甚至上亿条记录,在查找记录的时候,想要获得非常快的速度,就要使用索引。索引是关系数据表中对某一列/多个列的值进行预排序的数据结构。通过使用索引,可以让数据库系统不用扫描整个数据表,而是直接定位到符合条件的记录,大大提高了查询速度
索引的目的:提高查询速度
例:学生表
如果需要我们经常根据score
来进行查询,那么就可以对score
创建索引
ALTER TABLE students
ADD INDEX idx_score(score);
这其中idx_score
是索引的名字,使用列score
创建
也可以设置多个列
ALTER TABLE students
ADD INDEX idx_name_score(name, score);
索引的效率取决于索引列的值是否散列,即该列的值如果越不互相相同,则索引效率越高。反过来,如果记录的列存在大量相同的值,例如gender
不是男就是女,那对该列创建索引意义不大
可以对一张表创建多个索引
- 优点:在于提高了查询速度
- 缺点:插入、更新和删除记录时,需要同时修改索引
主键,关系数据表会自动创建主键索引,使用主键索引的效率是最高的,因为主键会保证绝对唯一
唯一索引
在关系数据表中看上去唯一的列,例如:身份证、邮箱……。由于他们具有业务含义,因此不宜作为主键。但是,这些列根据业务需求,确实具有唯一约束(两个人身份证不能相同哦),这个时候可以给列添加一个唯一索引,利用UNIQUE
字段
ALTER TABLE students
ADD UNIQUE INDEX uni_name(name);
设置了名字不重复
唯一约束
除了可以给某个列添加唯一索引,也可以添加唯一约束
没有索引了,只是添加了不能重复的约束
ALTER TABLE students
ADD CONSTRAINT uni_name UNIQUE(name);
这种情况下,name列没有索引,但是具有唯一性
小结
- 对数据表创建索引可以提高查询速度
- 通过创建唯一索引,可以保证某个列的值具有唯一性
- 数据库索引对用户和应用程序而言都是透明的