一、什么是索引

索引(Index),可以看作一个指针,指向表里的数据。当数据库没有索引时,查找信息通常是全表扫描;使用了索引,它就会直接引导到数据在表里的准确物理位置。

  • 优点:索引的主要目的是提高数据检索的性能,在数据量比较大时尤其明显。

  • 缺点

    1. 索引通常与相应的表是分开保存的,索引也会占据物理存储空间,而且可能比表本身还大。
    2. 索引的维护(索引项的添加和删除)有时间消耗,会影响数据检索的速度。

当为字段添加了索引后,索引里记录了与被索引字段相关联的位置值。当表里添加新数据时,索引里也会添加新项。如下图所示:

假设执行

SELECT * FROM table_name WHERE name='SMITH';

由于 where 条件里的 name 字段已经设置了索引,所以会首先在索引里搜索'SMITH',找到以后直接返回被搜索数据在表里的实际位置。

二、创建索引

创建索引使用CREATE INDEX命令或者ALTER TABLE...ADD...命令。数据库里的表可以创建多种类型的索引。

1. 单字段索引

单字段索引是基于一个字段创建的:

CREATE INDEX index_name ON table_name(column_name);

如果某个字段经常在 where 子句作为单独的查询条件,那么它的单字段索引是最有效的。

2. 唯一索引

唯一索引不允许被索引字段具有重复值,除此之外,它与普通索引的功能一样。

CREATE UNIQUE INDEX index_name ON table_name(column_name);

唯一索引用于改善性能和保证数据完整性。

3. 组合索引

组合索引是基于两个或多个字段创建的:

CREATE INDEX index_name ON table_name(column1, column2);

如果经常在where子句里联合使用两个或多个字段进行查询,可以考虑创建组合索引。

4. 隐含索引

隐含索引是数据库服务程序在创建对象时自动创建的。比如,数据库会为主键约束唯一性约束自动创建索引。

为什么给主键约束和唯一性约束自动创建索引?

主键约束和唯一性约束都要求字段的每个值都唯一。当用户向表中添加新记录时,为了有效地检查新值在成百上千的记录里是否唯一,对应的字段必须被索引。

三、删除索引

MySQL中删除索引使用ALTER TABLE或者DROP INDEX命令。两者的功能是一样的,事实上,DROP INDEX语句在内部被映射到一个ALTER TABLE语句中。

方法一:

ALTER TABLE table_name DROP INDEX index_name;

方法二:

DROP INDEX index_name ON table_name;

四、何时(不)应该使用索引

考虑使用索引的情况:

  1. 一般来说,大多数用于表结合的字段都应该设置索引。比如,外键经常用于与父表的结合,适合设置索引。

  2. 经常在order bygroup by里引用的字段应该考虑设置索引,因为索引会自动进行排序,简化了实际的排序操作,提高了输出结果的速度。

  3. 具有大量唯一值得字段,或是在where子句里会返回很小部分记录的字段,都可以考虑设置索引。

索引的初衷是提高数据检索的性能,但不要认为使用索引就能解决所有的问题,在一些情况下索引可能根本不会改善性能而只是占据磁盘空间。

  1. 索引不应该用于小规模的表。

  2. 当字段在where子句里作为条件会返回表里的大部分记录时,该字段不适合设置索引。

  3. 包含大量NULL值的字段不应该设置索引。索引对在不同记录中包含不同数据的字段特别有效,字段中过多的NULL值会严重影响索引的运行效率。

  4. 经常被更新的字段不应该设置索引。因为对索引的维护会变得很繁重。

个人站点:http://songlee24.github.com

MySQL基础笔记(四) 索引的更多相关文章

  1. MySQL基础(四)——索引

    MySQL基础(四)--索引

  2. MYSQL基础笔记(四)-数据基本操作

    数据操作 新增数据:两种方案. 1.方案一,给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致.凡是非数值数据,到需要使用引号(建议使用单引号)包裹. i ...

  3. MYSQL基础笔记(五)- 练习作业:站点统计练习

    作业:站点统计 1.将用户的访问信息记录到文件中,独占一行,记录IP地址 <?php //站点统计 header('Content-type:text/html;charset=utf-8'); ...

  4. MYSQL基础笔记(三)-表操作基础

    数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...

  5. MYSQL基础笔记(六)- 数据类型一

    数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...

  6. MYSQL基础笔记(二)-SQL基本操作

    SQL基本操作 基本操作:CRUD,增删改查 将SQL的基本操作根据操作对象进行分类: 1.库操作 2.表操作 3.数据操作 库操作: 对数据库的增删改查 新增数据库: 基本语法: Create da ...

  7. MYSQL基础笔记(一)

    关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...

  8. MySql学习笔记四

    MySql学习笔记四 5.3.数据类型 数值型 整型 小数 定点数 浮点数 字符型 较短的文本:char, varchar 较长的文本:text, blob(较长的二进制数据) 日期型 原则:所选择类 ...

  9. MySql基础笔记(二)Mysql语句优化---索引

    Mysql语句优化--索引 一.开始优化前的准备 一)explain语句 当MySql要执行一个查询语句的时候,它首先会对语句进行语法检查,然后生成一个QEP(Query Execution Plan ...

随机推荐

  1. 关于DTCC数据库技术大会

    本次DTCC数据库技术大会是第9届了,这次大会虽然有不少公司的产品推介,总体来说还是有不少干货的. 专场较多,有选择地主要听了大数据实践跟流式计算这块.网易跟滴滴的分享比较不错. 了解到了现在大家是用 ...

  2. 访问修饰词--Java

    public(公共的) 权限: 完全公开 protected(受保护的) 权限: 对子类和同包中的其他类公开 default(默认的,可不写) 权限: 对同包中的其他类公开 private(私有的) ...

  3. tornado框架基础01-路由简介

    tornado 小而精 Django 大而全 Web框架 Tornado是一个由Python开发的Web框架 Web服务 利用Tornado,可以快速搭建和一个高性能的Web服务 非阻塞 Tornad ...

  4. C语言学习10

    判断三角形的类型 根据输入的三角形的三条边判断三角形的类型,并输出它的面积. #include <stdio.h> #include <math.h> void judge_1 ...

  5. 分享下自己的EmpireofCode进攻策略 https://empireofcode.com/ https://empireofcode.com/game/#

    # 没什么用,该游戏的模块调用不友好,取数据难import queue from battle import commander # import math unit_client = command ...

  6. 嵩天老师的零基础Python笔记:https://www.bilibili.com/video/av15123607/?from=search&seid=10211084839195730432#page=25 中的42-45讲 {字典}

    #coding=gbk#嵩天老师的零基础Python笔记:https://www.bilibili.com/video/av15123607/?from=search&seid=1021108 ...

  7. 【POJ 1061】青蛙的约会(EXGCD)

    Description 两只青蛙在网上相识了,它们聊得很开心,于是觉得很有必要见一面.它们很高兴地发现它们住在同一条纬度线上,于是它们约定各自朝西跳,直到碰面为止.可是它们出发之前忘记了一件很重要的事 ...

  8. Leetcode 233.数字1的个数

    数字1的个数 给定一个整数 n,计算所有小于等于 n 的非负整数中数字 1 出现的个数. 示例: 输入: 13 输出: 6 解释: 数字 1 出现在以下数字中: 1, 10, 11, 12, 13 . ...

  9. Linux CentOS命令行界面字体重复问题解决记录

    问题描述: 安装完CentOS 6.5 mini版之后,安装图形界面,启动之后出现如下问题,字体有重复 应该是因为字体原因, 我的解决方法: yum -y install dejavu-sans-* ...

  10. 服务器安装oracle前的内存调整

    #当前内存大小为512MB,安装oracle时执行检查... Checking physical memory requirements ... Expected result: 922MB Actu ...