创建索引

第一种方式:在执行CREATE TABLE时创建索引

  1. CREATE TABLE user_index2 (
  2. id INT auto_increment PRIMARY KEY,
  3. first_name VARCHAR (16),
  4. last_name VARCHAR (16),
  5. id_card VARCHAR (18),
  6. information text,
  7. KEY name (first_name, last_name),
  8. FULLTEXT KEY (information),
  9. UNIQUE KEY (id_card)
  10. );

第二种方式:使用ALTER TABLE命令去增加索引

  1. ALTER TABLE table_name ADD INDEX index_name (column_list);

ALTER TABLE用来创建普通索引、UNIQUE索引或PRIMARY KEY索引。其中table_name是要增加索引的表名,column_list指出对哪些列进行索引,多列时各列之间用逗号分隔。索引名index_name可自己命名,缺省时,MySQL将根据第一个索引列赋一个名称。
另外,ALTER TABLE允许在单个语句中更改多个表,因此可以在同时创建多个索引。

第三种方式:使用CREATE INDEX命令创建

  1. CREATE INDEX index_name ON table_name (column_list);

CREATE INDEX可对表增加普通索引或UNIQUE索引。(但是,不能创建PRIMARY KEY索引)

删除索引

根据索引名删除普通索引、唯一索引、全文索引:alter table 表名 drop KEY 索引名

  1. alter table user_index drop KEY name;
  2. alter table user_index drop KEY id_card;
  3. alter table user_index drop KEY information;

删除主键索引:alter table 表名 drop primary key(因为主键只有一个)。这里值得注意的是,如果主键自增长,那么不能直接执行此操作(自增长依赖于主键索引):
Mysql索引 - 图1
需要取消自增长再行删除:

  1. alter table user_index
  2. -- 重新定义字段
  3. MODIFY id int,
  4. drop PRIMARY KEY

但通常不会删除主键,因为设计主键一定与业务逻辑无关