mysql的索引面试_mysql 索引详解

mysql的索引面试_mysql 索引详解1、什么是索引? 索引是帮助MySQL高效获取数据的数据结构(有序)。 在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现

MySQL索引详解,面试必问

1、什么是索引?

  索引是帮助MySQL高效获取数据的数据结构(有序)。

  在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。

  图示:

  mysql的索引面试_mysql 索引详解

  索引本身也很大,一般以索引文件的形式存在磁盘上。

 2、说一下索引有哪些优势有哪些劣势?

  优势:

    1、提高数据的查询效率,降低了数据库的IO成本;

    2、通过索引列对数据进行排序,可以大大降低排序的成本,即降低了CPU的消耗。

  劣势:

    1、实际上索引也是一张表,该表中保存了主键和索引字段,并指向实体表的记录,所以索引列也是要占用空间的;

    2、虽然索引大大提高了查询效率,但同时也降低了更新表的速度,如对表进行insert,update,delete。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。每次更新或添加了索引列的字段,都会调整因为更新所带来的键值变化后的索引信息。

 3、介绍一下索引的数据结构?

  索引是在MySQL的引擎层中实现的,所以每种存储引擎的索引都不一定完全相同,也不是所有的存储引擎都支持所有的索引类型。

  MySQL目前提供了以下四种结构的索引:

    1、BTREE索引:最常见的索引类型,大部分索引都支持B树索引。

    2、HASH索引:只有Memory引擎支持,适用场景简单。

    3、R-TREE索引:即空间索引,是MyISAM引擎的一个特殊索引类型,主要用于地理空间数据类型。

    4、Full-text索引:即全文索引,也是MyISAM引擎的一个特殊索引类型,主要用于全文检索,InnoDB从MySQL5.6开始支持全文检索。

  mysql的索引面试_mysql 索引详解

 

   我们平常所说的索引,如果没有特别指明,都指的是B+树索引。其中InnoDB引擎,默认使用的就是B+树结构的索引。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5628.html

(0)
上一篇 2023-05-01
下一篇 2023-05-01

相关推荐

  • mysql error hy000_you have an error in your sql

    mysql error hy000_you have an error in your sql摘要:Mysql出现问题:error while loading shared libraries: libaio解决方案。 本文分享自华为云社区《Mysql出现问题:error while load

    2023-06-08
    143
  • Python中的cmath模块

    Python中的cmath模块在Python中,有一个成为cmath的模块,它用于计算复数。复数可以看做是实数和虚数相加的形式,它在数学和物理学等领域有着广泛的应用。有了cmath模块,我们可以轻松地进行复数计算。下面我们将详细介绍Python中的cmath模块。

    2024-07-10
    37
  • oracle总结「终于解决」

    oracle总结「终于解决」1.创建表空间create tablespance 表名datafile ‘’;– 放在的位置size –设置大小autoextend onnext ; –扩展大小 — 2删除表空间drop

    2023-04-26
    160
  • 手把手教你接入华为分析的Android SDK「建议收藏」

    手把手教你接入华为分析的Android SDK「建议收藏」  公司最近开发了一个Android版手游应用,想了解一下上线以来玩家充值情况,就让我接入华为分析的AndroidSDK。今天我就来给大家分享一下如何将AnalyticsKit添加到安卓应用中去。本…

    2023-03-22
    152
  • Python Listbox with Tkinter: 完全指南

    Python Listbox with Tkinter: 完全指南Tkinter是Python中常用的图形用户界面(GUI)工具包之一。Tkinter具有一系列的小部件,可以轻松创建各种类型的GUI应用程序,其中之一是Listbox。Listbox是一个小部件,用于在窗口中显示一系列的项目,并允许用户通过单击列表中的项目进行选择。

    2024-01-14
    107
  • Python编程实例:用Python解析数据

    Python编程实例:用Python解析数据数据解析是指将一些结构化或半结构化数据从一种形式转换为另一种形式的过程。其中结构化数据与半结构化数据是指具有非常明显固定格式的数据,例如XML、JSON等;而非结构化数据则是指不具有固定格式的数据,例如文本、图片等。

    2024-03-25
    80
  • MySQL数据库性能优化[亲测有效]

    MySQL数据库性能优化[亲测有效]前言 由于部分企业要求本地部署系统(使用企业服务器进行部署系统且数据库也部署在同台服务器),本地部署系统的服务器往往达不到我们的云部署服务器,速度性能更是有所欠缺,特别是在查询统计报表的时候,云上几秒

    2023-05-16
    157
  • mssql sqlserver sql对使用逗号分隔的字符串 转换为数据表的另类方法实现[通俗易懂]

    mssql sqlserver sql对使用逗号分隔的字符串 转换为数据表的另类方法实现[通俗易懂]转自:http://www.maomao365.com/?p=10739 摘要: 下文讲述在sqlserver 对逗号分隔的字符串转换为数据表的另类方法实现,如下所示: 实验环境:sql server

    2022-12-21
    143

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注