zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

MySQL索引详解,这一篇绝对够 中

2023-03-14 22:46:17 时间

5.索引的分类和创建

create table member (id int (10) , name varchar (10) , cardid int (18) , phone int (11) , address varchar (50), remark text);

准备工作:安装MySQL数据库

imageimage

(1)普通索引

  • 最基本的索引类型,没有唯一性之类的限制。

●直接创建索引

CREATE INDEX 索引名 ON 表名 (列名[(length)]);

#(列名(length) ): length是可选项,下同。如果忽略length的值,则使用整个列的值作为索引。如果指定,使用列的前length个字符来创建索引,这样有利于减小索引文件的大小。

#索引名建议以”index"结尾。

create index name_index on member (name);

imageimage

修改表方式创建

ALTER TABLE 表名 ADD INDEX 索引名 (列名);

image

●创建表的时候指定索引

CREATE TABLE 表名 ( 字段1 数据类型,字段2 数据类型[,...],INDEX 索引名 (列名));

image

(2)唯一索引

  • 与普通索引类似,但区别是唯一索引列的每个值都唯一。唯一索引允许有空值(注意和主键不同)。如果是用组合索引创建,则列值的组合必须唯一。添加唯一键将自动创建唯一索引。

●直接创建唯一索引

CREATE UNIQUE INDEX 索引名 ON 表名(列名);
 
create unique index cardid_index on member(cardid);

image

●修改表方式创建

ALTER TABLE 表名 ADD UNIQUE 索引名 (列名);

image

●创建表的时候指定

CREATE TABLE 表名 (字段1 数据类型,字段2 数据类型[,... ],UNIQUE 索引名 (列名));

image

(3)主键索引

  • 是一种特殊的唯一索引,必须指定为"PRIMARY KEY"。一个表只能有一个主键,不允许有空值。添加主键将自动创建主键索引。

●创建表的时候指定

CREATE TABLE 表名 ([...],PRIMARY KEY (列名));

image

●修改表方式创建

ALTER TABLE 表名 ADD PRIMARY KEY (列名);
 
alter table member add primary key (id);

image

(4)组合索引(单列索引与多列索引)

可以是单列上创建的索引,也可以是在多列上创建的索引。需要满足最左原则,因为 select语句的 where条件是依次从左往右执行的,所以在使用select语句查询时where条件使用的字段顺序必须和组合索引中的排序一致,否则索引将不会生效。

CREATE TABLE 表名 (列名1 数据类型,列名2 数据类型,列名3 数据类型,INDEX 索引名 (列名1,列名2,列名3));
 
select * from 表名 where 列名1='...' AND 列名2='...' AND 列名3='...';

image