我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

了解了主键索引的底层原理,主键索引其实就是根据主键字段建立相关的数据结构(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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

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

下载Word文档

猜你喜欢

​oracle唯一索引和普通索引有什么不同

Oracle索引差异唯一索引与普通索引差异在于:数据完整性:唯一索引强制唯一性,普通索引不保证。约束:唯一索引隐含UNIQUE约束,普通索引需另定义。存储空间:唯一索引占用更多空间,普通索引占用更少。维护成本:唯一索引维护成本更高,普通索引维护成本较低。查询性能:唯一索引在独特列查询中性能优越,普通索引在非唯一列查询中性能更佳。使用场景:唯一索引用于保证数据唯一性,普通索引用于提高查询性能。优点:唯一索引保证数据唯一性,普通索引提高查询性能。缺点:唯一索引维护成本高,普通索引不保证唯一性。选择指南:根据数
​oracle唯一索引和普通索引有什么不同
2024-04-12

MySQL唯一索引和普通索引选哪个?

想象这样一个场景,在设计一张用户表时,每人的身份证号是唯一的,需要搜索。但由于身份证号字段较大,不好将其作为主键。在业务代码已经保证插入身份证唯一的情况下,可以选择建立唯一索引和普通索引,这时该如何选择呢?接下来,将从查询和更新的执行过程进
2022-05-28

MySQL 普通索引和唯一索引的区别详解

1 概念区分普通索引和唯一索引普通索引可重复,唯一索引和主键一样不能重复。 唯一索引可作为数据的一个合法验证手段,例如学生表的身份证号码字段,我们人为规定该字段不得重复,那么就使用唯一索引。(一般设置学号字段为主键)主键和唯一索引主键保证数
2022-05-25

MySQL主键索引和非主键索引的实现

目录主键索引(Primary Key Index):非主键索引(Secondary Index):在jsmysql中,主键索引和非主键索引有不同的作用和特点:主键索引(Pjavascriptrimary Key Index):主键索引是
2023-10-27

普通索引和唯一索引的执行过程

这里普通索引和唯一索引的情况有所不同查询过程对于普通索引来说,查找到满足条件的第一个记录后,需要查找下一个记录, 直到碰到第一个不满足条件的记录。对于唯一索引来说,由于索引定义了唯一性,查找到第一个满足条件的记录后,就会停止继续检索这个不同带来的性能差距会有多
普通索引和唯一索引的执行过程
2016-04-05

普通索引与唯一索引在MySQL 中有什么区别

这篇文章给大家介绍普通索引与唯一索引在MySQL 中有什么区别,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1 概念区分普通索引和唯一索引普通索引可重复,唯一索引和主键一样不能重复。 唯一索引可作为数据的一个合法验证手
2023-06-06

mysql的主键和索引

主键是个什么?我来来具体的东西说吧,书大家都看过吧,没看过的找本翻一下,看下它每页是不是有个页码,我们的数据表主键就相当于是这个页码,明白了吧。那么索引是什么呢?我们还拿书来说,索引相当于书的目录,有了目录我们可以很快的知道这本书的基本内容和结构,数据索引也一
mysql的主键和索引
2022-03-12

mysql怎么创建唯一索引

在MySQL中,可以使用CREATE INDEX语句来创建唯一索引。唯一索引是一种索引,其中每个索引值只能出现一次,用于保证表中的每条记录在索引列上的值都是唯一的。以下是创建唯一索引的语法示例:CREATE UNIQUE INDEX i
mysql怎么创建唯一索引
2024-04-09

MySQL唯一索引如何创建

要创建一个MySQL唯一索引,可以使用以下语法:ALTER TABLE table_nameADD UNIQUE INDEX index_name (column1, column2, ...);其中,`table_name`是要添加索
2023-10-27

mysql中唯一的索引关键字是

唯一索引关键字是 unique,用于确保表中指定列或列组合具有唯一值。创建唯一索引的好处包括:数据完整性、查询性能优化和唯一约束实施。MySQL 中唯一的索引关键字MySQL 中,用于创建唯一索引的关键字是 UNIQUE。什么是唯一索引
mysql中唯一的索引关键字是
2024-04-29

编程热搜

目录