0.定义

在关系数据库中,索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。

1.分类

— 主键索引primary key:唯一标识,主键不可重复,只能有一个列作为主键
— 唯一索引 uniQue key:避免重复的列出现,可以重复,多个列都可以标识为唯一索引
— 默认的,index key 关键字来设置
— 全文索引:在特定的数据库引擎下才有。

2.设置索引

上一篇中,我们生成了一百万条数据,下面我们继续测试

-- 创建索引
-- id_表名_字段名
-- CREATE INDEX 索引名 on 表(字段)
CREATE INDEX index_test_id on test(id); -- 创建花费2.346s

对比:

在为创建索引之前:

select * from test;   -- 3.171s
select * from  test WHERE id =1009980;  -- 1.162s

创建索引之后:

select * from  test WHERE id =1009980;  -- 0.080s

对于一百万条数据来说,创建索引可以缩短查询时间,对于数据量大的情况还是比较有用的。

分类: mysql