广告
返回顶部
首页 > 资讯 > 数据库 >Mysql 索引(三)—— 不同索引的创建方式(主键索引、普通索引、唯一键索引)
  • 545
分享到

Mysql 索引(三)—— 不同索引的创建方式(主键索引、普通索引、唯一键索引)

mysql数据库java 2023-09-12 22:09:51 545人浏览 八月长安
摘要

了解了主键索引的底层原理,主键索引其实就是根据主键字段建立相关的数据结构(B+树),此后在使用主键字段作为条件查询时,会直接根据主键查找B+树的叶子结点。除了主键索引外,普通索引和唯一键索引也是如此,只不过普通索引要稍微绕一点,下面会具体介

了解了主键索引的底层原理,主键索引其实就是根据主键字段建立相关的数据结构(B+树),此后在使用主键字段作为条件查询时,会直接根据主键查找B+树的叶子结点。除了主键索引外,普通索引和唯一键索引也是如此,只不过普通索引要稍微绕一点,下面会具体介绍。


目录

一、索引分类

1、主键索引

2、普通索引

3、唯一索引

二、创建索引的原则

三、创建索引

1、主键索引(primary key)

2、普通索引(index)

3、唯一索引(unique)

四、查询索引

五、删除索引


一、索引分类

1、主键索引

略。主键索引的概念这里就不再赘述了,本质就是根据主键在B+树上查找叶子结点。

具体介绍参考:Mysql 索引(一)—— 主键索引的底层原理_仲夏夜之梦~的博客-CSDN博客

2、普通索引

使用普通索引的场景:某个字段存在重复数据

主键索引是根据主键字段建立相关数据结构(B+树),而普通索引则是根据某个非主键字段建立对应的数据结构,此后检索时直接根据该非主键字段查找 B+ 树的叶子结点。普通索引属于非聚簇索引,不同存储引擎对应的普通索引的结构会有所不同。

(1) MyISAM

MyISAM 普通索引的创建方式和主键索引是一样的,叶子结点不保存任何数据,只保存数据记录的地址。

(2) InnoDB

InnoDB 普通索引和主键索引不一样,InnoDB 主键索引中叶子结点保存的是数据记录;而 InnoDB 普通索引中叶子结点保存的是主键索引值,后续要使用该主键索引值到主键索引中获取完整记录,这种方式叫回表查询。

3、唯一索引

使用唯一索引的前提条件:某个字段的内容不存在重复数据

(唯一索引使用的数据结构跟主键索引、普通索引是一样的,不同之处在于作为检索条件的字段不存在重复数据

二、创建索引的原则

第一点,查询频繁的字段应该作为索引。因为索引的目的就是提高检索效率,如果某个字段被频繁使用,使用字段作为检索条件时就有必要提高检索效率。

第二点,更新频繁的字段不适合作为索引。索引的高效是以增删改的效率为代价的。

第三点,不作为检索条件的,不适合作为索引。如果该字段都不会作为条件用于检索,只会出现在结果中,那该字段不适合作为索引。

三、创建索引

1、主键索引(primary key)

主键索引的创建:索引字段必须是主键,主键索引的字段类型一般都是 int,创建主键索引的关键字是primary key

(1) 建表时创建

-- 方式一:create table user1(    id int primary key,     -- 在创建表的时候,直接在字段名后指定 primary key    name varchar(30));-- 方式二:create table user1(    id int,    name varchar(30),    primary key(id)        -- 在创建表的最后,指定某列或某几列为主键索引);

(2) 建表后追加

create table user3(    id int,    name varchar(30));alter table user3 add primary key(id);    -- 创建表以后再添加主键

2、普通索引(index)

普通索引的创建:索引字段的数据允许重复。使用的关键字为 index

(1) 建表时创建

create table user(    id int primary key,    name varchar(20),    email varchar(30),    index(name)         --在表的定义最后,指定某列为索引);

(2) 建表后追加

create table user(    id int primary key,    name varchar(20),    email varchar(30));alter table user add index(name);     --创建完表以后指定某列为普通索引

3、唯一索引(unique)

唯一索引的创建:要求检索字段不能存在重复数据。使用的关键字为 unique。唯一索引的创建方式和普通索引完全一样,只需要把 index 关键字替换成 unique 关键字即可。

四、查询索引

查询某个表中的所有索引以及对应的字段

show index from 表名 [\G];

五、删除索引

(1) 删除主键索引

 alter table 表名 drop primary key;

注意:如果该主键已经被设为了自增(auto_increment),则该主键索引无法被删除。

(2) 删除其他索引(普通索引、唯一索引)

drop index 索引字段名 on 表名;

来源地址:https://blog.csdn.net/challenglistic/article/details/129166717

您可能感兴趣的文档:

--结束END--

本文标题: Mysql 索引(三)—— 不同索引的创建方式(主键索引、普通索引、唯一键索引)

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

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

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

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

下载Word文档
猜你喜欢
  • Mysql 索引(三)—— 不同索引的创建方式(主键索引、普通索引、唯一键索引)
    了解了主键索引的底层原理,主键索引其实就是根据主键字段建立相关的数据结构(B+树),此后在使用主键字段作为条件查询时,会直接根据主键查找B+树的叶子结点。除了主键索引外,普通索引和唯一键索引也是如此,只不过普通索引要稍微绕一点,下面会具体介...
    99+
    2023-09-12
    mysql 数据库 java
  • MySQL---单列索引(包括普通索引、唯一索引、主键索引)、组合索引、全文索引。
    1. 索引 索引是通过某种算法,构建出一个数据模型,用于快速找出在某个列中有一特定值的行,不使用索 引,MySQL必须从第一条记录开始读完整个表,直到找出相关的行,表越大,查询数据所花费的 时间就越多,如果表中查询的列有一个索引,MySQL...
    99+
    2023-09-21
    数据库 mysql sql
  • MySQL的几个概念:主键,外键,索引,唯一索引
    概念: 主键(primary key) 能够唯一标识表中某一行的属性或属性组。一个表只能有一个主键,但可以有多个候选索引。主键常常与外键构成参照完整性约束,防止出现数据不一致。主...
    99+
    2022-10-18
  • MySQL唯一索引和普通索引选哪个?
    想象这样一个场景,在设计一张用户表时,每人的身份证号是唯一的,需要搜索。但由于身份证号字段较大,不好将其作为主键。在业务代码已经保证插入身份证唯一的情况下,可以选择建立唯一索引和普通索引,这时该如何选择呢?接下来,将...
    99+
    2022-05-28
    MySQL 唯一索引 MySQL 普通索引
  • MySQL 主键、索引创建
    创建测试表create table t1.t (a int,b varchar(200)); -- 添加主键、索引alter table t1.t add primary key (a);alte...
    99+
    2022-10-18
  • MySQL 普通索引和唯一索引的区别详解
    1 概念区分 普通索引和唯一索引 普通索引可重复,唯一索引和主键一样不能重复。 唯一索引可作为数据的一个合法验证手段,例如学生表的身份证号码字段,我们人为规定该字段不得重复,那么就使用唯一索引。(一般...
    99+
    2022-05-25
    MySQL 普通索引 MySQL 唯一索引
  • MySQL普通索引和唯一索引的深入讲解
    场景 1、维护一个市民系统,有一个字段为身份证号 2、业务代码能保证不会写入两个重复的身份证号(如果业务无法保证,可以依赖数据库的唯一索引来进行约束) 3、常用SQL查询语句:SELECT n...
    99+
    2022-10-18
  • 普通索引和唯一索引的执行过程
    这里普通索引和唯一索引的情况有所不同 查询过程 对于普通索引来说,查找到满足条件的第一个记录后,需要查找下一个记录, 直到碰到第一个不满足条件的记录。 对于唯一索引来说,由于索引定义了唯一性,查找到第一个满足条件的记录后,就会停止继续检索 ...
    99+
    2016-04-05
    普通索引和唯一索引的执行过程
  • MySQL主键索引和非主键索引的实现
    目录主键索引(Primary Key Index):非主键索引(Secondary Index):在mysql中,主键索引和非主键索引有不同的作用和特点: 主键索引(Primary Key Index): 主键索引是一种...
    99+
    2023-10-27
    MySQL 主键索引 MySQL 非主键索引
  • mysql主键索引和普通索引之间有什么区别
    这篇文章主要介绍mysql主键索引和普通索引之间有什么区别,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存...
    99+
    2022-10-18
  • 普通索引与唯一索引在MySQL 中有什么区别
    这篇文章给大家介绍普通索引与唯一索引在MySQL 中有什么区别,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1 概念区分普通索引和唯一索引普通索引可重复,唯一索引和主键一样不能重复。 唯一索引可作为数据的一个合法验证手...
    99+
    2023-06-06
  • mysql的主键和索引
    主键是个什么 我来来具体的东西说吧,书大家都看过吧,没看过的找本翻一下,看下它每页是不是有个页码,我们的数据表主键就相当于是这个页码,明白了吧。 那么索引是什么呢? 我们还拿书来说,索引相当于书的目录,有了目录我们可以很快的知道这本...
    99+
    2022-03-12
    mysql的主键和索引 数据库入门 数据库基础教程 数据库 mysql
  • MySQL唯一索引如何创建
    要创建一个MySQL唯一索引,可以使用以下语法: ALTER TABLE table_name ADD UNIQUE INDEX...
    99+
    2023-10-27
    MySQL
  • mysql中主键是不是索引
    小编给大家分享一下mysql中主键是不是索引,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!mysql中主键不是索引。主键全称“主键约束”,是对表中数据的一种约束,它是表的一个特殊字段,该字...
    99+
    2022-10-19
  • mysql 创建索引的三种方式
    1、使用CREATE INDEX创建,语法如下: CREATE INDEX indexName ON tableName (columnName(length)); 2、使用ALTER语句创建,语法如下: ALTER TABLE ...
    99+
    2023-09-07
    mysql
  • [MySQL] innoDB引擎的主键与聚簇索引
    mysql的innodb引擎本身存储的形式就必须是聚簇索引的形式 , 在磁盘上树状存储的 , 但是不一定是根据主键聚簇的 , 有三种情形: 有主键的情况下 , 主键就是聚簇索引 没有主键的情况下 , 第一个非空null的唯一索...
    99+
    2020-07-02
    [MySQL] innoDB引擎的主键与聚簇索引
  • 【创建索引的三种方式】
    创建索引的三种方式 第一种方式:在执行 CREATE 第二种方式:使用 ALTER TABLE 命令去增加索 ALTER TABLE table_name ADD INDEX index_name ...
    99+
    2023-09-02
    数据库 mysql sql
  • mysql唯一索引和主键的区别是什么
    本篇内容介绍了“mysql唯一索引和主键的区别是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-18
  • mysql有主键还需要创建索引吗
    小编给大家分享一下mysql有主键还需要创建索引吗,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!mysql主键不需要建立索引,主键具备索引的功能;当创建或设置主键的时候,mysql会自动添加一...
    99+
    2022-10-18
  • 什么是mysql中唯一索引的关键字
    本篇文章为大家展示了什么是mysql中唯一索引的关键字,代码简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。mysql中唯一索引的关键字是unique index。创建唯一...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作