1.索引的快速入门
说起提高数据库性能,索引是最物美价廉的东西了,不用加内存,不用改程序,不用调sql,查询速度就可能提高百倍千倍
2.索引的原理
没有索引为什么会慢?因为全表扫描
使用索引为什么会快?形成一个索引的数据结构
索引的代价
(1)磁盘占用
(2)对增删改语句的效率影响(平时在我们的项目中,select占据90%)
3.索引的类型
(1)主键索引,主键自动为主索引(类型Primary key)
(2) 唯一索引
(3)普通索引
(4)全文索引
create table t1(
iid int primary key --主键,同时也是索引,称为主键索引
name varchar(32);
create table t2(
id int unique, --id是唯一的,同时也是索引,称为unique索引
4.索引的使用
--
演示
mysql
的索引的使用
--
创建索引
CREATE TABLE t25 (
id INT ,
`name` VARCHAR(32));
--
查询表是否有索引
SHOW INDEXES FROM t25;
--
添加索引
--
添加唯一索引
CREATE UNIQUE INDEX id_index ON t25 (id);
--
添加普通索引方式
1
CREATE INDEX id_index ON t25 (id);
--
-
如何选择
-- 1.
如果某列的值,是不会重复的,则优先考虑使用
unique
索引
,
否则使用普通索引
--
添加普通索引方式
2
ALTER TABLE t25 ADD INDEX id_index (id)
--
添加主键索引
CREATE TABLE t26 (
id INT ,
`name` VARCHAR(32));
ALTER TABLE t26 ADD PRIMARY KEY (id)
SHOW INDEX FROM t25
--
删除索引
DROP INDEX id_index ON t25
--
删除主键索引
ALTER TABLE t26 DROP PRIMARY KEY
--
修改索引 , 先删除,在添加新的索引
--
查询索引
-- 1.
方式
SHOW INDEX FROM t25
-- 2.
方式
SHOW INDEXES FROM t25
5.索引使用的场景
(1)较频繁的作为查询字段应该创建索引
(2)唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件
如性别为男
(3)更行非常频繁的字段不适合创建索引
(4)不会出现在Where子句中字段不应该创建索引