MySQL - 表的创建_表索引_普通索引详解

创建和查看索引

创建索引是指在某个表的一列或多列上建立一个索引,以便提高对表的访问速度。创建索引有3种方式,分别是创建表的时候创建索引、在已经存在的表上创建索引和使用ALTER TABLE语句来创建索引。本节将根据具体的索引分类详细的讲解这3种创建方法。

1. 普通索引

所谓普通索引,就是在创建索引时,不附加任何限制条件(唯一、非空等限制)。该类型的索引可以创建在任何数据类型的字段上。

创建表时定义索引

CREATE TABLE tablename(
propname1 type1,
propname2 type2,
……
propnamen type…n,
INDEX | KEY
[indexname] (propnamen [(length)] [ ASC | DESC ] ) );

其中,参数INDEX和KEY是用来指定字段为索引的,两者选择其中之一就可以了,作用是一样的;参数indexname是索引名字,可省略;参数propnamen是索引对应的字段的名称,该字段必须为前面定义好的字段;参数length是可选参数,其指索引的长度,必须是字符串类型才可以使用;参数ASC和DESC都是可选参数,ASC表示升序排列,DESC表示降序排列,如果不指定,则为升序。

mysql> create database school;   #创建数据库school  
mysql> use school;   #选择数据库school  
mysql> create table class(id int, name varchar(128) UNIQUE, teacher varchar(64), INDEX index_no(id DESC));       #创建表class, 并建立为id 字段索引  
mysql> show create table class;  #查看表结构 
mysql> insert into class values(1, '一班', 'Martin');  # 插入记录1 
mysql> insert into class values(1, '二班', 'Rock');   # 插入记录2 
mysql> select * from class where id > 0 ;   #根据id查询记录,结果将降序排列  

具体操作

MySQL - 表的创建_表索引_普通索引详解_第1张图片
MySQL - 表的创建_表索引_普通索引详解_第2张图片
MySQL - 表的创建_表索引_普通索引详解_第3张图片
MySQL - 表的创建_表索引_普通索引详解_第4张图片
MySQL - 表的创建_表索引_普通索引详解_第5张图片
但是索引能增加查找速度

方法一:
已存在的表上创建索引
MySQL - 表的创建_表索引_普通索引详解_第6张图片
方法二:
已存在的表上创建索引
MySQL - 表的创建_表索引_普通索引详解_第7张图片
MySQL - 表的创建_表索引_普通索引详解_第8张图片
MySQL - 表的创建_表索引_普通索引详解_第9张图片
MySQL - 表的创建_表索引_普通索引详解_第10张图片
MySQL - 表的创建_表索引_普通索引详解_第11张图片
在这里插入图片描述

结语:

时间: 2020-07-09

你可能感兴趣的:(MySQL,mysql,索引)