一、概述

1.基本概念

      在大型数据库中,一张表中要容纳几万、几十万,甚至几百万的的数据,而当这些表与其他表连接后,所得到的新的数据数目更是要大大超出原来的表。当用户检索这么大量的数据时,经常会感觉慢。这个时候要提高数据库的检索性能,就必须要用到索引。给表追加合适的索引能极大的改善数据检索的效率,提供数据库性能。

     索引是在存储引擎中实现的,因此每种存储引擎的索引都不一定完全相同,而且每种存储引擎也不一定支持所有的索引类型。

     所有存储引擎支持每个表至多16个索引,总索引长度至多为256字节。

     MySql中的索引的存储类型有两种: B-Tree和Hash,MyISAM和InnoDB存储引擎只支持B-Tree索引。Memory和Heap可以支持Hash和B-Tree索引。

     为表设置索引是要付出代价的:

     (1)增加了数据库的存储空间。

     (2)插入和修改数据时要花费较多的时间(因为索引的位置也要随之变动)。

 

2.索引的优缺点

(1)优点

a: 通过创建唯一索引,保证数据库表每行数据的唯一性。

b: 大大加快数据查询速度。

c: 在使用分组和排序进行数据查询时,可以显著减少查询中分组和排序的时间。

 

(2)缺点

a: 维护索引需要耗费数据库资源。

b: 索引需要占用磁盘空间,索引文件可能比数据文件更快达到最大文件尺寸。

c: 当对表的数据进行增删改的时候,因为要维护索引,速度会受到影响。

 

      索引是建立在数据库表中的某些列的上面。在创建索引的时候,应该考虑在哪些列上可以创建索引,在哪些列上不能创建索引。一般来说,应该在这些列上创建索引。

a: 在经常需要搜索的列上,可以加快搜索的速度;

b: 在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构;

c: 在经常用在连接的列上,这些列主要是一些外键,可以加快连接的速度;

d: 在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的;

e: 在经常需要排序的列上创建索引,因为索引已经排序,这样查询可以利用索引的排序,加快排序查询时间;

f: 在经常使用在WHERE子句中的列上面创建索引,加快条件的判断速度。

 

一般来说,不应该创建索引的的这些列具有下列特点

a: 对于那些在查询中很少使用或者参考的列不应该创建索引。这是因为,既然这些列很少使用到,因此有索引或者无索引,并不能提高查询速度。相反,由于增加了索引,反而降低了系统的维护速度和增大了空间需求。

b: 对于那些只有很少数据值的列也不应该增加索引。这是因为,由于这些列的取值很少,例如人事表的性别列,在查询的结果中,结果集的数据行占了表中数据行的很大比例,即需要在表中搜索的数据行的比例很大。增加索引,并不能明显加快检索速度。

c: 对于那些定义为text, image和bit数据类型的列不应该增加索引。这是因为,这些列的数据量要么相当大,要么取值很少。

d: 当修改性能远远大于检索性能时,不应该创建索引。这是因为,修改性能和检索性能是互相矛盾的。当增加索引时,会提高检索性能,但是会降低修改性能。当减少索引时,会提高修改性能,降低检索性能。因此,当修改性能远远大于检索性能时,不应该创建索引。

 

二、索引的分类

1.普通索引

     这是最基本的索引,它没有任何限制,比如上文中为title字段创建的索引就是一个普通索引,MyIASM中默认的BTREE类型的索引,也是我们大多数情况下用到的索引。

#直接创建索引
CREATE INDEX index_name ON TABLE (COLUMN(length)); #修改表结构的方式添加索引
ALTER TABLE table_name ADD INDEX index_name ON (COLUMN(length)); #创建表的时候同时创建索引
CREATE TABLE `table` (
`id` INT (11) NOT NULL AUTO_INCREMENT,
`title` CHAR (255) CHARACTER
SET utf8 COLLATE utf8_general_ci NOT NULL,
`content` text CHARACTER
SET utf8 COLLATE utf8_general_ci NULL,
`time` INT (10) NULL DEFAULT NULL,
PRIMARY KEY (`id`),
INDEX index_name (title(length))
); #删除索引
DROP INDEX index_name ON TABLE;

 

2.唯一索引

     唯一索引是不允许其中任何两行具有相同索引值的索引。

     索引列的值必须唯一,但允许有空值,注意和主键不同。    

     当现有数据中存在重复的键值时,大多数数据库不允许将新创建的唯一索引与表一起保存。数据库还可能防止添加将在表中创建重复键值的新数据。例如,如果在employee表中职员的姓(lname)上创建了唯一索引,则任何两个员工都不能同姓。

#创建唯一索引
CREATE UNIQUE INDEX indexName ON TABLE (COLUMN); #修改表结构
ALTER TABLE table_name ADD UNIQUE indexName ON (COLUMN); #创建表的时候直接指定
CREATE TABLE `table` (
`id` INT (11) NOT NULL AUTO_INCREMENT,
`title` CHAR (255) CHARACTER
SET utf8 COLLATE utf8_general_ci NOT NULL,
`content` text CHARACTER
SET utf8 COLLATE utf8_general_ci NULL,
`time` INT (10) NULL DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE indexName (title)
);

 

3.全文索引

     FULLTEXT索引可以用于全文搜索。只有MYISAM存储引擎支持FULLTEXT索引,并且只支持CHAR、VARCHAR和TEXT类型。

#创建表的适合添加全文索引
CREATE TABLE `table` (
`id` INT (11) NOT NULL AUTO_INCREMENT,
`title` CHAR (255) CHARACTER
SET utf8 COLLATE utf8_general_ci NOT NULL,
`content` text CHARACTER
SET utf8 COLLATE utf8_general_ci NULL,
`time` INT (10) NULL DEFAULT NULL,
PRIMARY KEY (`id`),
FULLTEXT (content)
); #修改表结构添加全文索引
ALTER TABLE article ADD FULLTEXT index_content (content); #直接创建索引
CREATE FULLTEXT INDEX index_content ON article (content);

 

4.复合索引

     联合索引又叫复合索引。对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。例如索引是key index (a,b,c). 可以支持a | a,b| a,b,c 3种组合进行查找,但不支持 b,c进行查找 .当最左侧字段是常量引用时,索引就十分有效。

     利用索引中的附加列,您可以缩小搜索的范围,但使用一个具有两列的索引 不同于使用两个单独的索引。复合索引的结构与电话簿类似,人名由姓和名构成,电话簿首先按姓氏对进行排序,然后按名字对有相同姓氏的人进行排序。如果您知 道姓,电话簿将非常有用;如果您知道姓和名,电话簿则更为有用,但如果您只知道名不姓,电话簿将没有用处。

所以说创建复合索引时,应该仔细考虑列的顺序。对索引中的所有列执行搜索或仅对前几列执行搜索时,复合索引非常有用;仅对后面的任意列执行搜索时,复合索引则没有用处.

    

ALTER TABLE article ADD INDEX index_titme_time (title(50), time(10));

建立这样的组合索引,其实是相当于分别建立了下面两组组合索引:

–title,time

–title

     为什么没有time这样的组合索引呢?这是因为MySQL组合索引“最左前缀”的结果。简单的理解就是只从最左面的开始组合。并不是只要包含这两列的查询都会用到该组合索引,如下面的几个SQL所示:

#会使用到上面的索引
SELECT * FROM article WHREE title='测试' AND time=1234567890;
SELECT * FROM article WHREE utitle='测试'; #不会使用上面的索引
SELECT * FROM article WHREE time=1234567890;

MySQL学习笔记(三)—索引的更多相关文章

  1. MYSQL学习笔记三:日期和时间函数

    MYSQL学习笔记三:日期和时间函数 1. 获取当前日期的函数和获取当前时间的函数 /*获取当前日期的函数和获取当前时间的函数.将日期以'YYYY-MM-DD'或者'YYYYMMDD'格式返回 */ ...

  2. MySql学习笔记三

    MySql学习笔记三 4.DML(数据操作语言) 插入:insert 修改:update 删除:delete 4.1.插入语句 语法: insert into 表名 (列名1,列名2,...) val ...

  3. mysql学习笔记--数据库索引

    一.索引的优点:查询速度快 二.索引的缺点: 1. 增.删.改(数据操作语句)效率低了 2. 索引占用空间 三.索引类型: 1. 普通索引 2. 唯一索引(唯一键) 3. 主键索引:只要主键就自动创建 ...

  4. mysql学习笔记三 —— 数据恢复与备份

    要点: 1.存储引擎2.导入导出3.备份与恢复 查看当前数据库中的所有表use db1:show tables: 1.存储引擎 不同的发动机(引擎)适用的汽车类型不一样. 存储和处理的不同方式.不同的 ...

  5. MySQL学习笔记三:库和表的管理

    1.MySQL数据库服务配置好后,系统会有4个默认的数据库. information_schema:虚拟对象,其对象都保存在内存中 performance_schema:服务器性能指标库 mysql: ...

  6. mysql基本数据类型(mysql学习笔记三)

    Mysql数据类型 小数: 浮点:小数位可以变化 Float单精度默认精度6位左右 Double 双精度默认精度16位左右 支持,控制数值范围 Type(M,D) M表示所有数值位数(不包括小数点和符 ...

  7. MySQL学习笔记(三):常用函数

    一:字符串函数 需要注意的几个细节: 1.cancat中有一个字符串为null,则结果为null. 2.left(str,x) 和 right(str,x)中x为null,则不返回任何字符串,不是nu ...

  8. mysql学习笔记(三)

    -- 主键冲突(duplicate key) ,'xujian','anhui'); ,'xiewei','anhui'); ,'luyang','anhui');-- 主键冲突了 -- 可以选择性的 ...

  9. MySql学习笔记(三) —— 聚集函数的使用

    1.AVG() 求平均数 select avg(prod_price) as avg_price from products; --返回商品价格的平均值 ; --返回生产商id为1003的商品价格平均 ...

随机推荐

  1. MySQL账户管理

    body { font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height: 1.6; padding-top: 10 ...

  2. ubuntu16.04下安装配置深度学习环境(一、cuda7.5的安装)

    1.下载所需要的软件 cuda7.5下载(点击下载链接),cudnn4.0下载 2.安装NVIDIA驱动. 一般有两种方法:1)一种方法是利用"软件和更新"来安装,依次选择 系统设 ...

  3. 概念 : 过程 : 前台login

    为了解决自动登入.访问权限机制.登入权限而诞生了这过程,过程需要概念来维护记忆. 通过singlePageAutoLoginLocalStorage, UIStateLocalStorage, Use ...

  4. 每天一个Linux命令(13)--less命令

    less 工具也是对文件或其它输出进行分页显示的工具,应该说是Linux正统馋看文件内容的工具,功能极其强大.less 的用法比起  more 更加有弹性.  在 more 的时候,我们没有办法向前面 ...

  5. 每天一个Linux命令(10)--cat命令

    --首先,恭喜你,这是第十个命令啦. --为啥第十个就要恭喜?没啥特别呀? --因为逢十进一啊! cat命令的用途是连接文件或标准输入并打印.这个命令常用来显示文件内容,或者将几个文件连接起来显示,或 ...

  6. Javascript中关于作用域和闭包和域解释的面试题

    <script type="text/javascript"> function fn() { var i = 10; return function (n) { co ...

  7. 2017 3-4/5 两天的学习的REVIEW

    明天就要去面试啦,去感受一下,估计又是一顿虐,蓝瘦-- 3月4日:计算机安全基础技术与原理方面的学习 密码体制(密码)由五个部分组成: 消息空间(m),密文空间(c),密钥空间(k),加密算法(E), ...

  8. 利刃 MVVMLight 4:绑定和绑定的各种使用场景

    一.绑定: 主要包含元素绑定和非元素绑定两种. 1.元素绑定,是绑定的最简单形式,源对象是WPF的元素,并且源对象的属性是依赖项属性. 根据我们之前的知识 ,依赖项属性具有内置的更改通知支持.所以当我 ...

  9. PetaPoco 快速上手

    今天来给大家分享一个好用的轻型的.net框架的ORM——PetaPoco 本着快速上手的原则,我们通过和EF对比,让大家能快速使用PetaPoco PetaPoco大家可能没有听说过,但大家一定听说过 ...

  10. 强化学习读书笔记 - 06~07 - 时序差分学习(Temporal-Difference Learning)

    强化学习读书笔记 - 06~07 - 时序差分学习(Temporal-Difference Learning) 学习笔记: Reinforcement Learning: An Introductio ...