MySQL基础之第7章 索引
第7章 索引
MySQL中,所有的数据类型都可以被索引,包括普通索引,唯一性索引,全文索引,单列索引,多列索引和空间索引等。
7.1、索引简介
7.1.1、索引的含义和特点
BTREE索引,HASH索引
优点:提高查询,联合查询,分级和排序的时间
缺点:索引占空间,维护(创建,更新,维护)索引时需要耗费时间
7.1.2、索引的分类
1、普通索引
不加任何限制条件
2、唯一性索引
使用UNIQUE参数
3、全文索引
使用FULLTEXT参数,只能创建在CHAR,VARCHAR,TEXT类型的字段上,只有MyISAM存储引擎支持全文索引。
4、单列索引
在一个字段上建立的普通索引,唯一性索引或全文索引
5、多列索引
在多个字段上建立的普通索引,唯一性索引或全文索引
6、空间索引
使用SPATIAL参数,只有MyISAM存储引擎支持空间索引,必须建立在空间数据类型上,且必须非空,初学者很少用到。
7.1.3、索引的设计原则
1、选择唯一性索引
2、为经常需要排序、分组和联合操作的字段建立索引
如ORDER BY、GROUP BY、DISTINCT,UNION等操作的字段,特别是排序
3、为常作为查询条件的字段建立索引
4、限制索引的数目
避免过多地浪费空间
5、尽量使用数据量少的索引
6、尽量使用前缀来索引
如指索引TEXT类型字段的前N个字符
7、删除不再使用或者很少使用的索引
7.2、创建索引
三种方式:
1、 创建表时创建索引
2、 已经存在的表上创建索引
3、 使用ALTER TABLE语句来创建索引
7.2.1、创建表的时候创建索引
CREATE TABLE 表名 (属性名 数据类型 [完整约束条件],
属性名数据类型 [完整约束条件],
…
[UNIQUE|FULLTEXT|SPATIALINDEX|KEY [别名] (属性名1 [(长度)] [ASC|DESC])
);
1、创建普通索引
CREATE TABLEindex1 (id INT,
name VARCHAR(20),
sex BOOLEAN,
INDEX(id)
);
SHOW CREATETABLE index1\G;
2、创建唯一性索引
CREATE TABLEindex2(id INT UNIQUE,
name VARCHAR(20),
UNIQUE INDEX index2_id(id ASC)
);
SHOW CREATETABLE index2\G;
看到在字段id上建立了两个唯一索引id和index2_id,当然这样是没有必要的。
3、创建全文索引
CREATE TABLEindex3 (id INT,
info VARCHAR(20),
FULLTEXT INDEX index3_info(info)
) ENGINE=MyISAM;
4、创建单列索引
CREATE TABLEindex4 (id INT,
subject VARCHAR(30),
INDEXindex4_st(subject(10))
);
注意:只索引subject前10个字符
5、创建多列索引
CREATE TABLEindex5 (id INT,
name VARCHAR(20),
sex CHAR(4),
INDEX index5_ns(name,sex)
);
EXPLAIN select *from index5 where name=’123’\G;
EXPLAIN select *from index5 where name=’123’and sex=’N’\G;
6、创建空间索引
CREATE TABLEindex6 (id INT,
Space GEOMETRY NOT NULL,
SPATIAL INDEX index6_sp(space)
)ENGINE=MyISAM;
7.2.2、在已经存在的表上创建索引
CREATE [UNIQUE|FULLTEXT|SPATIAL]INDEX 索引名 ON 表名 (属性名[(长度)] [ASC|DESC]);
1、创建普通索引
CREATE INDEX index7_id on example0(id);
2、创建唯一性索引
CREATE UNIQUEINDEX index_8_id ON index8(course_id);
3、创建全文索引
CREATE FULLTEXTINDEX index9_info ON index9(info);
4、创建单列索引
CREATE INDEX index10_addr ON index10(address(4));
5、创建多列索引
CREATE INDEX index11_na ON index11(name, address);
6、创建空间索引
CREATE SPATIALINDEX index12_line on index12(line);
7.2.3、用ALTER TABLE语句来创建索引
ALTER TABLE 表名 ADD [UNIQUE|FULLTEXT|SPATIAL] INDEX 索引名 (属性名[(长度)][ASC|DESC]);
1、创建普通索引
ALTER TABLE example0 ADD INDEX index12_name(name(20));
2、创建唯一性索引
ALTER TABLE index14 ADD UNIQUE INDEX index14_id(course_id);
3、创建全文索引
ALTER TABLE index15 ADD INDEX index15_info(info);
4、创建单列索引
ALTER TABLE index 16 ADD INDEX index16_addr(address(4));
5、创建多列索引
ALTER TABLE index17 ADD INDEX index17_na(name, address);
6、创建空间索引
ALTER TABLE index18 ADD INDEX index18_line(line);
7.3、删除索引
DROP INDEX 索引名 ON 表名;
DROP INDEX id ONindex1;
MySQL基础之第7章 索引的更多相关文章
- MySQL基础之第18章 性能优化
18.1.优化简介 SHOW STATUS LIKE ‘value’;connections 连接数uptime 启动 ...
- MySQL基础之第5章 操作数据库
假设已经登录 mysql-h localhost -uroot -proot 5.1.显示.创建.删除数据库 show databases; 显示所有的数据库 create database ...
- MySQL基础之第1章 数据库概述
1.1.数据存储方式 1.人工管理阶段2.文件系统阶段3.数据库系统阶段 1.2.数据库泛型 数据库泛型就是数据库应该遵循的规则.数据库泛型也称为范式.目前关系数据库最常用的四种范式分别是:第一范式( ...
- MySQL基础笔记(四) 索引
一.什么是索引 索引(Index),可以看作一个指针,指向表里的数据.当数据库没有索引时,查找信息通常是全表扫描:使用了索引,它就会直接引导到数据在表里的准确物理位置. 优点:索引的主要目的是提高数据 ...
- MySQL基础之第17章 MySQL日志
17.1.日志简介 二进制日志错误日志通用查询日志慢查询日志 17.2.二进制日志 二进制日志也叫作变更日志(update log),主要用于记录数据库的变化情况.通过二进制日志可以查询MySQL数据 ...
- MySQL基础之第16章 数据备份与还原
16.1.数据备份 16.1.1.使用 mysqldump 命令备份 mysqldump [OPTIONS] database [tables]mysqldump [OPTIONS] --databa ...
- MySQL基础之第15章 MySQL用户管理
15.2.账户管理 15.2.1.登录和退出MySQL服务器 mysql –hhostname|hostIP –P port –u username –p[password] databaseName ...
- MySQL基础之第14章 存储过程和函数
避免编写重复的语句 安全性可控 执行效率高 14.1.创建存储过程和函数 14.1.1.创建存储过程 CREATE PROCEDUREsp_name ([proc_parameter[,...]]) ...
- MySQL基础之第13章 MySQL函数
13.1.数学函数 随机数可能会用到,其他基本无视. 13.2.字符串函数 重点CONCAT(S1,S2….) 13.3.日期和时间函数 一.MySQL 获得当前日期时间 函数 1.1 获得当前日期+ ...
随机推荐
- DC-DC升压(BOOST)电路原理
BOOST升压电路中: 电感的作用:是将电能和磁场能相互转换的能量转换器件,当MOS开关管闭合后,电感将电能转换为磁场能储存起来,当MOS断开后电感将储存的磁场能转换为电场能,且这个能量在和 ...
- gulp-css-spriter 雪碧图合成
一.配置 gulp的雪碧图功能没有grunt那么强大,但是类似功能也支持,功能稍微弱一些,但是也很棒 npm地址:https://www.npmjs.com/package/gulp-css-spri ...
- java基础知识回顾之---java StringBuilder与StringBuffer异同点
/* * StringBuilder与StringBuffer异同点: * * 使用方法与StringBuffer完全一样 * Str ...
- lintcode:previous permutation上一个排列
题目 上一个排列 给定一个整数数组来表示排列,找出其上一个排列. 样例 给出排列[1,3,2,3],其上一个排列是[1,2,3,3] 给出排列[1,2,3,4],其上一个排列是[4,3,2,1] 注意 ...
- windows下顽固软件卸载不了的解决方法
下面以autocad2012举例: cad2012卸载显示 “无法获得同类产品” 而且也安装不上. 解决方法:1,开始>运行>输入"regedit",找到下面的注册表路 ...
- javascript基础之数组对象
一.定义数组的方法: 定义了一个空数组: var myArray =new Array(); 指定有n个空元素的数组: var myArray=new Array(n); 定义数组并赋值: var m ...
- 用于主题检测的临时日志(383b4f88-5dc7-4b08-a585-27104eb4ee7f - 3bfe001a-32de-4114-a6b4-4005b770f6d7)
这是一个未删除的临时日志.请手动删除它.(1e2a0af2-731b-4f82-9aa0-4e2d10ed7a1a - 3bfe001a-32de-4114-a6b4-4005b770f6d7)
- Sql Server查询性能优化之走出索引的误区
据了解绝大多数开发人员对于索引的理解都是一知半解,局限于大多数日常工作没有机会.也什么没有必要去关心.了解索引,实在哪天某个查询太慢了找到查询条件建个索引就ok,哪天又有个查询慢了,再建立个索引就是, ...
- 素数筛法--SPOJ Problem 2 Prime Generator
质数(prime number)又称素数,除了1和它本身外,不能整除以其他自然数,换句话说就是该数除了1和它本身以外不再有其他的因数:否则称为合数.最小的质数是2. 要判断一个整数N是不是质数很简单, ...
- IOS刷新数据
在一个项目开发过程中为了更好的体验经常会用到下拉刷新更新数据,当然也伴随一些上拉加载更多数据的情况:当前比较火的EGOTableViewPullRefresh只实现了下拉功能,而没有上拉的功能.这里介 ...