MySQL数据库基础之索引相关知识点整理

数据库对象索引的出现,除了可以提高数据库管理系统的查找速度,而且还可以保证字段的唯一性,从而实现数据库表的完整性。

MySQL支持6种索引:普通索引、唯一索引、全文索引、单列索引、多列索引和空间索引。

以下情况适合创建索引:

  • 经常被查询的字段,即在WHERE子句种出现的字段
  • 在分组的字段,即在GROUP BY子句中出现的字段
  • 存在依赖关系的子表和父表之间的联合查询,即主键或外键字段
  • 设置唯一完整性约束的字段

以下情况,不适合创建索引

  • 在查询中很少被使用的字段
  • 拥有许多重复值的字段

索引的操作包括创建索引、查看索引和删除索引。

创建和查看普通索引

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

语法形式如下:

创建表时创建普通索引

CREATE TABLE table_name (
    属性名 数据类型,
    属性名 数据类型,
    ...
    属性名 数据类型
    INDEX|KEY 【索引名】(属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】 )
)

在已经存在的表上创建普通索引

CREATE INDEX 索引名 ON 表名 (属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】)

通过SQL语句ALTER TABLE创建普通索引

ALTER TABLE table_name ADD INDEX|KEY 索引名 (属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】)

创建和查看唯一索引

所谓唯一索引,就是在创建索引时,限制索引的值必须时唯一的。通过该类型的索引可以更快速地查询某条记录。

根据创建索引方式,可以分为自动索引和手动索引。

当表中的某个字段被设置成主键或唯一完整性约束时,系统就会自动创建关联该字段的唯一索引。

语法形式如下:

创建表时创建唯一索引

CREATE TABLE table_name (
    属性名 数据类型,
    属性名 数据类型,
    ...
    属性名 数据类型,
    UNIQUE INDEX|KEY 索引名 (属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】)
)

在已经存在的表上创建唯一索引

CREATE UNIQUE INDEX 索引名 ON 表名 (属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】)

通过SQL语句ALTER TABLE创建唯一索引

ALTER TABLE table_name ADD UNIQUE INDEX|KEY 索引名 (属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】)

创建和查看全文索引

全文索引主要关联在数据类型为CHAR、VARCHAR和TEXT的字段上,以便能够更加快速地查询数据量较大的字符串类型的字段。

在默认情况下,全文索引得搜索执行方式为不区分大小写,如果全文索引所关联得字段为二进制数据类型,则以区分大小写得搜索方式执行。

语法形式如下

创建表时创建全文索引

CREATE TABLE table_name (
    属性名 数据类型,
    属性名 数据类型,
    ...
    属性名 数据类型,
    FULLTEXT INDEX|KEY 索引名 (属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】)
)

在已经存在得表上创建全文索引

CREATE FULLTEXT INDEX 索引名 ON 表名 (属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】)

通过SQL语句ALTER TABLE创建全文索引

ALTER TABLE table_name ADD FULLTEXT INDEX|KEY 索引名 (属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】)

创建和查看多列索引

所谓多列索引,是指在创建索引时,所关联得字段不是一个字段,而是多个字段。虽然可以通过所关联得字段进行查询,但是只有查询条件中使用了所关联字段中得第一个字段,多列索引才会被使用。

语法形式如下

创建表时创建多列索引

CREATE TABLE table_name (
    属性名 数据类型,
    属性名 数据类型,
    ...
    属性名 数据类型,
    INDEX|KEY 索引名  (
        属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】,
        属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】,
        ...
        属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】,
        )
)

在已经存在得表上创建多列索引

CREATE INDEX 索引名
    ON 表名 (
            属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】,
            属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】,
            ...
            属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】,
        )

通过SQL语句ALTER TABLE创建多列索引

ALTER TABLE table_name 
    ADD INDEX|KEY 索引名 (
            属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】,
            属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】,
            ...
            属性名【索引所关联的字段的名称】 (长度【可选】) ASC|DESC【可选,排序方式,升|降】,
        )

删除索引

DROP INDEX|KEY 索引名 ON table_name

原创文章,作者:ZERO,如若转载,请注明出处:https://www.edu24.cn/course/mysql-index.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
ZEROZERO
上一篇 2020年7月7日
下一篇 2020年7月13日

相关推荐

  • JavaWeb入门案例之用户注册

    前言 之前把Java的基础知识系统的过了一遍,目前总算可以看懂Java代码了,接下来就是要学习Java开发框架(主要是springMVC)。 下面用一个用户注册的小案例,来总结一下…

    2021年1月13日
    1.7K
  • Spring Tools学习之JAVA开发环境搭建【windows 10】

    一直以来都想学习JAVA,但是苦于找不到门路,网上学习资料要不看不懂,要不需要金钱。 终于,迫于生活与年龄的压力,下定决心,学习JAVA。 写下此文档,记录一下自己学习JAVA之路…

    2018年12月6日
    3.0K
  • Webpack入门,模块打包原理分析

    面对工程中成百上千个模块,Webpack究竟是如何将它们有序地组织在一起,并按照开发者预想的顺序运行在浏览器上的呢?本篇文章将通过一个简单的示例。分析一下Webpack模块打包的原…

    2022年11月14日
    816
  • JavaScript 事件委托详解

    基本概念 事件委托,通俗地来讲,就是把一个元素响应事件(click、keydown……)的函数委托到另一个元素; 一般来讲,会把一个或者一组元素的事件委托到…

    2021年3月8日
    1.2K
  • spring boot练习篇之用户登录系统【接入数据库】

    抛弃JSP,只做纯粹的前后端分离项目。 写在前面 学习基础知识是枯燥无味的,之所以会这样,多数是因为心不静,对于如何运用它,感到茫然。所以建议大家在学习Java基础知识的时候,一定…

    2021年5月28日
    1.3K
  • CSS多列等高布局

    在项目开发中,经常遇到需要多列等高布局的需求。解决这种的需求的方法有很多,各有利弊,现总结如下。 方法一:使用flex布局 优点:实现方便,还可以方便实现各种比例 ; 缺点: IE…

    2019年6月11日
    2.2K
  • Angular环境搭建(Windows 10)

    目前前端开发正处于快速发展阶段,接触angular时,Angular 2刚刚发布,现在第五版也已经发布。由于刚开始没有系统的学习,导致工作中,经常捉襟见肘。现在把自己在工作中踩过的…

    2018年9月5日
    4.1K
  • MyBatis配置之typeHandler类型处理器

    typeHandler类型处理器作用 MyBatis在预处理语句(PreparedStatement)中设置一个参数时,或者从结果集(ResultSet)中取出一个值时,都会用注册…

    2022年4月20日
    1.2K
  • 5分钟带你入门vuex(vue状态管理)

    如果你之前使用过vue.js,你一定知道在vue中各个组件之间传值的痛苦,在vue中我们可以使用vuex来保存我们需要管理的状态值,值一旦被修改,所有引用该值的地方就会自动更新,那…

    2019年11月5日
    2.1K
  • spring4.x学习之用户登录与注册

    在之前的文章中我已经把后端工程项目创建好了,接下来就是编写项目了。 首先,我先创建一个数据库。数据库使用的是MySQL,数据库管理工具用的是Navicat。 打开数据库管理工具Na…

    2019年3月21日
    2.1K

发表回复

登录后才能评论