MySQL入门很简单: 5 索引
1. 索引的含义和特点
索引:创建在表上,是对数据库表中一列或多列的值进行排序的一种结构。
存储类型: B性树(BTREE)索引和哈希(HASH)索引; InnoDB和MyISAM支持BTREE索引, MEMORY支持BTREE索引和HASH索引
优缺点: 优点——提高检索数据的速度; 缺点: 创建和维护索引需要耗费时间
2. 索引分类
1)普通索引:不加任何限制条件
2)唯一性索引:使用UNIQUE参数(主键就是一种特殊唯一性索引)
3)全文索引: 使用FULLTEXT参数,只能创建在CHAR VARCHER或TEXT类型的字段上
4)单列索引: 在表中的单个字段上创建索引,唯一性索引或全文索引
5)多列索引: 在表的多个字段上创建一个索引;唯一性索引或全文索引
6)空间索引:使用SPATIAL参数,只有MyISAM存储引擎支持空间索引,必须建立在空间数据类型上,切必须非空
3. 如何设计索引
4. 创建索引
三种方式:创建表时创建索引, 在已经存在的表上创建索引,使用ALTER TABLE语句创建
4.1 创建表的时候创建索引
1)创建普通索引
在表的id字段建立索引
CREATE TABLE index1(id INT,
name VARCHAR(20),
sex BOOLEAN,
INDEX(id)
);
2)创建唯一性索引
CREATE TABLE index2(id INT UNIQUE,
name VARCHAR(20),
UNIQUE INDEX index2_id(id ASC)
);
3)创建全文索引
CREATE TABLE index3(id INT,
info VARCHAR(20),
FULLTEXT INDEX index3_info(info)
)ENGINE=MyISAM;
4)创建单列索引
CREATE TABLE index4(id INT,
subject VARCHAR(20),
INDEX index4_st(subject(10))
);
5)创建多列索引
CREATE TABLE index5(id INT ,
name VARCHAR(20),
sex CHAR(4),
INDEX index5_ns(name, sex)
);
6)创建空间索引
CREATE TABLE index6(id INT ,
space GEOMETRY NOT NULL,
SPATIAL INDEX index6_sp(space)
)ENGINE=MyISAM;
4.2 在已经存在的表上创建索引
CREATE [UNIQUE | FULLTEXT | SPATIAL ] INDEX 索引表
ON 表名 (属性名 [ (长度)] [ ASC | DESC ]
1)创建普通索引
在examp0表的id字段建立名为index7_id的索引 CREATE INDEX index7_id ON example0(id)
2)创建唯一性索引
在index8表中的course_id字段建立名为index8_id的唯一性索引 CREATE UNIQUE INDEX index8_id ON index8(course_id);
3)创建全文索引
在index9表中的info字段建立名为index9_info的全文索引
CREATE FULLTEXT INDEX index9_info ON index9(info);
4)创建单列索引
在index10表中的address字段上建立名为index10_addr的单列索引
CREATE INDEX index10_addr ON index10(address(4));
5)创建多列索引
在index11表中的name和address字段上建立名为index11_na的多列索引 CREATE INDEX index11_na ON index11(name,address);
6)创建空间索引
在index12表中的line字段上建立名为index12_line的多列索引 CREATE SPATIAL INDEX index12_line ON index12(line);
4.3 用ALTER TABLE语句创建索引
ALTER TABLE 表名 ADD [ UNIQUE | FULL TEXT | SPATIAL] INDEX
索引名(属性名 [(长度)] [ ASC | DESC]);
1)创建普通索引
在example0表中的name字段建立名为index13_name的索引 ALTER TABLE example0 ADD INDEX index13_name(name(20));
2)创建唯一性索引
ALTER TABLE index14 ADD UNIQUE INDEX index14_id(course_id);
3)创建全文索引
ALTER TABLE index15 ADD FULLTEXT INDEX index15_info(info);
4)创建单列索引
ALTER TABLE index16 ADD INDEX index16_addr(address(4));
5)创建多列索引
ALTER TABLE index17 ADD INDEX index17_na(name, address);
6)创建空间索引
ALTER TABLE index18 ADD SPATIAL INDEX index18_line(line);
5. 删除索引
DROP INDEX 索引名 ON 表名;
MySQL入门很简单: 5 索引的更多相关文章
- 《Mysql 入门很简单》(读后感①)
下载完整版<Mysql 入门很简单>,点击这里~: http://files.cnblogs.com/files/zhengyeye/MySQL%E5%85%A5%E9%97%A8%E5% ...
- MySQL入门很简单: 1 数据库概述
1. 数据库概述 1.1 数据存储方式: 1)人工管理阶段 2)文件系统阶段: 文件系统通过文件的存储路径和文件名称访问文件中的数据 3)数据库系统阶段:Oracle, SQL Server, MyS ...
- MySQL入门很简单-触发器
1.触发器是由事件来触发某个操作,这些事件包括insert语句.update语句和delete语句.当数据库系统执行这些事件时,会激活触发器执行相应操作.MySQL从5.0.2开始支持触发器.使用触发 ...
- MySQL入门很简单: 15 java访问MySQL数据库
1. 连接数据库 1.1 下载安装驱动 java通过JDBC(Java Database Connectivity,Java数据库连接)来访问MySQL数据库.JDBC的编程接口提供的接口和类与MyS ...
- MySQL入门很简单: 14MySQL日志
二进制日志: 以二进制文件的形式记录了数据库中的操作,但不记录查询语句 错误日志: 记录MySQL服务器的启动,关闭和运行错误等信息 通用查询日志: 记录用户登录和记录查询的信息 慢查询日志: 记录执 ...
- MySQL入门很简单: 13 数据备份和还原
1. 数据备份 1)使用mysqldump命令备份 第一种:备份一个数据库 mysqldump -u username -p dbname table1 table2 ... > BackupN ...
- MySQL入门很简单: 12 MYSQL 用户管理
1. 权限表 安装MySQL会自动安装一个名为mysql的数据库,存储权限表: user表, db表,host表,table_priv表,columns_priv表,proc_priv表等. 1)us ...
- MySQL入门很简单: 8查询数据
1. 查询语句语法 SELECT 属性列表 FROM 表名和视图列表 [WHERE 条件表达式1] [GROUP BY 属性名1 [HAVING t条件表达式2]] [ORDER BY 属性名2 [A ...
- MySQL入门很简单: 6 视图
1. 视图含义作用 视图是虚拟的表,是从数据率中一个或多个表中导出来的表: 数据库中只存放了视图的定义,没有存放视图中的数据,数据在原先的表中: 一旦表中的数据发生变化,显示在视图中的数据也会发生 ...
随机推荐
- 洛谷2015(树形dp)
要点 是树形的考虑dfs 分为取一枝,取两枝两种情况,将它们的合法情况进行暴举取最好答案即可,貌似我乱搞得相当冗-- 顺手记忆化 正解应该是树上背包 #include <cstdio> # ...
- 优先队列priority_queue的简单应用
优先队列 引入 优先队列是一种特殊以及强大的队列. 那么优先队列是什么呢? 说白了,就是一种功能强大的队列. 它的功能强大在哪里呢? 四个字:自动排序. 优先队列的头文件&&声明 头文 ...
- jq自定义鼠标右键菜单
效果: 代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <t ...
- pandas关于其他merge用法(df1的的列索引和df2的行索引对应时候的)
- day18 约束 异常
1. 类的约束 方案一:抛出异常,子类必须重写父类方法,否则会报错 class Base: def login(self): #强制xxx做XXX事 raise NotImplementedError ...
- 修改阿里云ESC Centos 7.4 防火墙开放端口
例如系统:Centos 7.4操作如下 1,进入 cd /etc/firewalld/zones/ 目录 2,编辑 vim public.xml 3,按i或insert键进入编辑模式 4,在<z ...
- 关于 java中的SecureRandom在linux中每次生成不同结果
使用AES算法的时候,会发现下面的代码在windows每次产生确定的结果,但Linux就不同,导致无法正确解密 public static String encrypt(String content, ...
- delphi 与 java 兼容的 MD5
function GetMd5(AValue : string) : string; var md5 : TIdHashMessageDigest5; bytes,byte1 : TBytes; be ...
- 汉诺塔问题hdu 2065——找规律
这类题目就是纸上模拟,找规律. 问题描述:在一块铜板上有三根杆,目的是将最左边杆上的盘全部移到右边的杆上,条件是不允许直接从最左(右)边移到最右(左)边(每次移动一定是移到中间杆或从中间移出),也不允 ...
- Problem01 不死神兔
题目:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子对数为多少? 程序分析:兔子的规律为数列1,1,2,3,5,8,13,21 ...