广告
返回顶部
首页 > 资讯 > 数据库 >快速了解MySQL 索引
  • 109
分享到

快速了解MySQL 索引

MySQL索引 2022-05-16 16:05:43 109人浏览 薄情痞子
摘要

Mysql索引的建立对于mysql的高效运行是很重要的,索引可以大大提高Mysql的检索速度。 打个比方,如果合理的设计且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是一个人力三轮车。

Mysql索引的建立对于mysql的高效运行是很重要的,索引可以大大提高Mysql的检索速度。

打个比方,如果合理的设计且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是一个人力三轮车。

索引分单列索引和组合索引。单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引。组合索引,即一个索包含多个列。

创建索引时,你需要确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE 子句的条件)。

实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。

上面都在说使用索引的好处,但过多的使用索引将会造成滥用。因此索引也会有它的缺点:虽然索引大大提高了查询速度,同时却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。

建立索引会占用磁盘空间的索引文件。

普通索引

创建索引

这是最基本的索引,它没有任何限制。它有以下几种创建方式:


CREATE INDEX indexName ON mytable(username(length)); 

如果是CHAR,VARCHAR类型,length可以小于字段实际长度;如果是BLOB和TEXT类型,必须指定 length。

修改表结构


ALTER mytable ADD INDEX [indexName] ON (username(length)) 

创建表的时候直接指定


CREATE TABLE mytable( 
 
ID INT NOT NULL, 
 
username VARCHAR(16) NOT NULL, 
 
INDEX [indexName] (username(length)) 
 
);

删除索引的语法


DROP INDEX [indexName] ON mytable; 

唯一索引

它与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。它有以下几种创建方式:

创建索引


CREATE UNIQUE INDEX indexName ON mytable(username(length)) 

修改表结构


ALTER mytable ADD UNIQUE [indexName] ON (username(length)) 

创建表的时候直接指定


CREATE TABLE mytable( 
 
ID INT NOT NULL, 
 
username VARCHAR(16) NOT NULL, 
 
UNIQUE [indexName] (username(length)) 
 
);

使用ALTER 命令添加和删除索引

有四种方式来添加数据表的索引:

  • ALTER TABLE tbl_name ADD PRIMARY KEY (column_list): 该语句添加一个主键,这意味着索引值必须是唯一的,且不能为NULL。
  • ALTER TABLE tbl_name ADD UNIQUE index_name (column_list): 这条语句创建索引的值必须是唯一的(除了NULL外,NULL可能会出现多次)。
  • ALTER TABLE tbl_name ADD INDEX index_name (column_list): 添加普通索引,索引值可出现多次。
  • ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list):该语句指定了索引为 FULLTEXT ,用于全文索引。

以下实例为在表中添加索引。


mysql> ALTER TABLE testalter_tbl ADD INDEX (c);

你还可以在 ALTER 命令中使用 DROP 子句来删除索引。尝试以下实例删除索引:


mysql> ALTER TABLE testalter_tbl DROP INDEX (c);

使用 ALTER 命令添加和删除主键

主键只能作用于一个列上,添加主键索引时,你需要确保该主键默认不为空(NOT NULL)。实例如下:


mysql> ALTER TABLE testalter_tbl MODIFY i INT NOT NULL;
mysql> ALTER TABLE testalter_tbl ADD PRIMARY KEY (i);

你也可以使用 ALTER 命令删除主键:


mysql> ALTER TABLE testalter_tbl DROP PRIMARY KEY;

删除指定时只需指定PRIMARY KEY,但在删除索引时,你必须知道索引名。

显示索引信息

你可以使用 SHOW INDEX 命令来列出表中的相关的索引信息。可以通过添加 \G 来格式化输出信息。

尝试以下实例:


mysql> SHOW INDEX FROM table_name\G
........

以上就是快速了解MySQL 索引的详细内容,更多关于MySQL 索引的资料请关注自学编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: 快速了解MySQL 索引

本文链接: https://www.lsjlt.com/news/9658.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 快速了解MySQL 索引
    MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。 打个比方,如果合理的设计且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是一个人力三轮车。...
    99+
    2022-05-16
    MySQL 索引
  • 一文快速入门 MySQL 索引
    什么是索引 MySQL 官方对索引的定义:索引(Index)是帮助 MySQL高效获取数据的数据结构。因此 索引的本质就是数据结构。索引的目的在于提高查询效率,可类比字典、书籍的目录等这种形式。 可简单理解为 排好序的快速查找数据...
    99+
    2015-09-22
    一文快速入门 MySQL 索引
  • 【Mysql】快速定位不合理的索引——MySQL索引调优(一)
    原文地址:http://mp.weixin.qq.com/s__biz=MjM5MjIxNDA4NA==&mid=401131835&idx=1&sn=37c5fd9d3d8670f...
    99+
    2022-10-18
  • 【MySQL】快速了解MySQL基础
    登录MySQL后我们可以使用命令 show databases,来查看有哪些数据库。 show databases; 如果我们想创建一个数据库可以使用 create database 数据库名 [ch...
    99+
    2023-10-20
    mysql 数据库
  • 深入了解mysql索引
    1、索引原理 索引被用来快速找出在一个列上用一特定值的行。没有索引,MySQL不得不首先以第一条记录开始,然后读完整个表直到它找出相关的行。表越大,花费时间越多。对于一个有序字段,可以运用二分查找(Binary Se...
    99+
    2022-05-14
    MySQL 索引
  • MySQL的索引你了解吗
    目录一、索引介绍二、索引优缺点三、索引结构1. 经典B+树2. MySQL中B+树索引3. Hash索引4. 为什么InnoDB选择B+树索引?   四、索引分类五、索引语法六、SQ...
    99+
    2022-11-13
  • MySQL全文索引、联合索引、like查询、json查询速度哪个快
    查询背景 有一个表tmp_test_course大概有10万条记录,然后有个json字段叫outline,存了一对多关系(保存了多个编码,例如jy1577683381775) 我们需要在这10万条数据中检索特定类型的...
    99+
    2022-05-15
    mysql 全文索引 mysql 联合索引 mysql like查询 mysql json查询
  • 五分钟让你快速弄懂MySQL索引下推
    目录前言什么是索引下推索引下推优化的原理索引下推的具体实践没有使用ICP使用ICP相关系统参数总结前言 如果你在面试中,听到MySQL5.6”、“索引优化” 之类的词语,你就要立马g...
    99+
    2022-11-12
  • 使用MySQL索引如何快速检索数据库的案例
    这篇文章将为大家详细讲解有关使用MySQL索引如何快速检索数据库的案例,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、索引的概念1、索引是一个排序的列表,在这个列表中存...
    99+
    2022-10-18
  • 你是否想了解 Java 索引教程?让 NPM 帮助你快速入门!
    Java 是一种广泛使用的编程语言,被广泛应用于 Web 开发、移动应用程序和企业级应用程序等领域。在 Java 中,索引是非常重要的概念,它可以让我们更快地访问和搜索数据。本文将为您介绍 Java 索引的基本概念,并通过 NPM 工具帮助...
    99+
    2023-07-27
    索引 教程 npm
  • MySQL创建索引需要了解的
    前言:  在 MySQL 中,基本上每个表都会有索引,有时候也需要根据不同的业务场景添加不同的索引。索引的建立对于数据库高效运行是很重要的,本篇文章将介绍下创建索引相关知识及注意事项。 1.创建索引方法 创...
    99+
    2022-05-17
    MySQL 索引 MySQL 创建索引
  • 快速入门MySQL数据库索引的基础知识
    本文主要给大家介绍快速入门MySQL数据库索引的基础知识,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下快速入门MySQL数据库索引的基础知识吧。--...
    99+
    2022-10-18
  • mysql索引为什么会快
    mysql索引快速的原因有:1、减少数据扫描量,将数据按照特定的规则进行排序;2、加速排序和分组操作,当查询包含排序、分组或聚合函数时,索引可以大大减少排序和分组操作的时间复杂度;3、避免重复数据读取,将相同的数据存储在一起,减少了重复记录...
    99+
    2023-07-28
  • 快速了解Spring Boot
    今天给大家介绍一下Spring Boot MVC,让我们学习一下如何利用Spring Boot快速的搭建一个简单的web应用。环境准备一个称手的文本编辑器(例如Vim、Emacs、Sublime Text)或者IDE(Eclipse、Ide...
    99+
    2023-05-30
    spring boot 快速入门
  • mysql百万数据快速创建索引的具体步骤
    下面一起来了解下mysql百万数据快速创建索引的具体步骤,相信大家看完肯定会受益匪浅,文字在精不在多,希望mysql百万数据快速创建索引的具体步骤这篇短内容是你想要的。     ...
    99+
    2022-10-18
  • 一文简单了解MySQL前缀索引
    当要索引的列字符很多时 索引则会很大且变慢 ( 可以只索引列开始的部分字符串 节约索引空间 从而提高索引效率 ) 原则: 降低重复的索引值 例如现在有一个地区表 areagdpcod...
    99+
    2022-11-13
  • 怎么利用MySQL技能快速了解MongoDB
    本篇内容介绍了“怎么利用MySQL技能快速了解MongoDB”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!...
    99+
    2022-10-18
  • Oracle大表怎么快速建立索引
    这篇文章主要介绍“Oracle大表怎么快速建立索引”,在日常操作中,相信很多人在Oracle大表怎么快速建立索引问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Oracle大表...
    99+
    2022-10-19
  • oracle索引失效怎么快速重建
    要快速重建Oracle索引,可以使用以下几种方法: 使用ALTER INDEX语句重建索引: ALTER INDEX index...
    99+
    2023-10-25
    oracle
  • 了解Python文件索引的工作原理,轻松实现文件快速加载。
    Python文件索引是Python解释器在加载模块时用来快速查找文件位置的一种机制。它通过在模块搜索路径中建立索引缓存,从而实现了文件位置的快速定位。在本文中,我们将详细介绍Python文件索引的工作原理,并演示如何使用它来实现文件的快速加...
    99+
    2023-09-28
    文件 索引 load
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作