【MySql】数据库索引

这篇具有很好参考价值的文章主要介绍了【MySql】数据库索引。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

索引

可以简单理解为一本书的目录信息,是为了提升查找效率而建立的

索引的创建

1、在创建一个主键、唯一键、外键时候,数据库会自动地针对查找字段设置索引;

【MySql】数据库索引

2、在创建表时侯,使用 index 关键字进行普通索引的声明

【MySql】数据库索引
【MySql】数据库索引

3、修改表结构,给指定的字段添加索引
alter table 表名 add index 索引名(要增加索引信息的列名)

【MySql】数据库索引

【MySql】数据库索引

4、为指定的表创建索引
create index 索引名 on 表名(列名)

【MySql】数据库索引
创建索引信息之后在进行索引的查看,发现新增了一个索引信息----即我们刚刚创建的索引信息:

【MySql】数据库索引

索引的查看

1、show index from 表名;
2、show keys from 表名;
3、desc 表名;

索引的删除

1、drop index 索引名 on tablename;

2、修改表结构:
alter table 表名 drop index 索引名;

数据库中数据信息在底层实际上是存储在 InnoDB 中的:
【MySql】数据库索引

而(InnoDB)索引实际上是采用 数据结构中 B+ 树结构来实现的

(注意区分B 树、B+树的区别)

【MySql】数据库索引
【MySql】数据库索引

聚簇索引 & 非聚簇索引

mysql 数据库中,InnoDB 存储引擎默认使用聚簇索引,MyISAM 存储引擎默认使用非聚簇索引

聚簇索引

索引数据与用户数据存放在一起;
一张表中只有一个聚簇索引;
聚簇索引数据与索引物理存储顺序是一致的,且有序存储;
在表中除了聚簇索引还有辅助索引,而聚簇索引类型中,辅助索引的叶子节点中存放的并不是用户数据,而是聚簇索引的键值;

【MySql】数据库索引
【MySql】数据库索引

非聚簇索引

索引数据与用户数据分离存储;
非聚簇索引是索引与数据分离,索引的叶子节点中存储的是数据的物理地址,因此索引的顺序与数据在物理磁盘的实际存储顺序不一定一致;
非聚簇索引的辅助索引,与主键索引并无区别,都是叶子节点中存放地址;

【MySql】数据库索引

【MySql】数据库索引

索引创建原则

1、比较频繁作为查询条件的字段应该创建索引;
2、唯一性太差的字段不适合创建索引,即使被频繁查询;
3、频繁修改的字段不适合创建索引------维护成本高;
4、索引并不是越多越好,因此不会作为查询条件的字段就不要创建索引。文章来源地址https://www.toymoban.com/news/detail-438048.html

到了这里,关于【MySql】数据库索引的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL数据库唯一索引

    创建索引是指在某个表的一列或多列上建立一个索引,以便提高对表的访问速度。创建索引有3种方式,分别是1.创建表的时候创建索引、2.在已经存在的表上创建索引和使用3.ALTER TABLE语句来创建索引。 本文福利, 莬 费领取Qt开发学习资料包、技术视频,内容包括(C++语言基

    2024年02月08日
    浏览(43)
  • MySQL数据库索引的数据结构

    数据库索引的功能就是让查找更加的高效,所以索引的数据结构应该是能够加速查找的数据结构。 MySQL的innoDB存储引擎的索引的数据结构就是多叉搜索树中的b+树,这可以说是为索引量身定做的一个数据结构。 首先,索引可以通过主键,unique修饰创建,也可以直接使用sql语句

    2024年02月10日
    浏览(44)
  • 【MySQL数据库 | 第十七篇】索引以及索引结构介绍

    目录 前言: 索引简介:  索引结构:           二叉树索引结构         Tree(普通二叉树)         B-Tree(多路平衡查找树)         B+Tree          哈希索引数据结构 总结: 在实际生活中,我们对SQL语句进行优化实际上有很大一部分都是对索引进行优化,因此对索引

    2024年02月09日
    浏览(57)
  • 【MySql系列】深入解析数据库索引

    MySQL索引是数据库中一个关键的概念,它可以极大地提高查询性能,加快数据检索速度。但是,要充分发挥索引的作用,需要深入理解它们的工作原理和使用方式。 在本文中,我们将深入解析MySQL索引,探讨它们的重要性、类型、创建、维护以及最佳实践。 在数据库中,索引

    2024年02月08日
    浏览(61)
  • MySQL数据库索引的种类、创建、删除

    目录 一:MySQL 索引 1、MySQL 索引介绍 2、 索引的作用  3、索引的副作用 4、 创建索引的原则依据  二、索引的分类和创建 1、 普通索引 (1) 直接创建索引 (2) 修改表方式创建 (3) 创建表的时候指定索引 2、 唯一索引 (1) 直接创建唯一索引 (2) 修改表方式创建

    2024年02月09日
    浏览(42)
  • 【Mysql系列】——详细剖析数据库“索引”【上篇】

        😎博客昵称:博客小梦 😊最喜欢的座右铭:全神贯注的上吧!!! 😊作者简介:一名热爱C/C++,算法,数据库等技术、喜爱运动、热爱K歌、敢于追梦的小博主! 😘博主小留言:哈喽! 😄各位CSDN的uu们,我是你的博客好友小梦,希望我的文章可以给您带来一定的帮

    2024年02月02日
    浏览(43)
  • MySQL数据库的ID列添加索引

    要为MySQL数据库的ID列添加索引,可以使用以下语法: 其中, table_name 是要添加索引的表名, index_name 是索引的名称, id 是要添加索引的列名。 例如,如果要为名为 users 的表的 id 列添加索引,可以执行以下语句: 这将在 users 表的 id 列上创建名为 idx_id 的索引。 需要注意的

    2024年02月07日
    浏览(42)
  • B+树:MySQL数据库索引的实现

    作为一个软件开发工程师,你对数据库肯定再熟悉不过了。作为主流的数据存储系统,它在我们的业务开发中,有着举足轻重的地位。在工作中,为了加速数据库中数据的查找速度,我们常用的处理思路是,对表中数据创建索引。那你是否思考过,数据库索引是如何实现的呢

    2024年02月09日
    浏览(49)
  • 【MySQL索引与优化篇】数据库的设计规范

    在关系型数据库中,关于数据表设计的基本原则、规则就称为范式 。范式的英文名称是 Normal Form ,简称 NF 。它是英国人 E.F.Codd 在上个世纪70年代提出关系数据库模型后总结出来的。范式是关系数据库理论的基础,也是我们在设计数据库结构过程中所要遵循的 规则 和 指导方

    2024年02月05日
    浏览(61)
  • 【从删库到跑路】MySQL数据库的索引(二)——索引的使用和选择

    🎊专栏【MySQL】 🍔喜欢的诗句:更喜岷山千里雪 三军过后尽开颜。 🎆音乐分享【The Right Path】 🥰欢迎并且感谢大家指出小吉的问题 🎈没有创建索引时,执行SQL语句,查看SQL的耗时 🎈 创建索引后 ,执行SQL语句,查看SQL的耗时 比较发现,时间减少了 🎈细节 创建索引 相

    2024年02月16日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包