MySQL索引学习笔记

两个索引都是B+树索引,但是myisam的表存储和索引存储是分开的,索引存储中存放的是表的地址。而innodb表存储本身就是一个B+树,

myisam和innodb的索引有什么区别?

两个索引都是B+树索引,但是myisam的表存储和索引存储是分开的,索引存储中存放的是表的地址。而innodb表存储本身就是一个B+树,它是用主键来做B+树的key的。

因此innodb需要设置主键,如果没有的话,mysql会优先使用unique键做主键,如果没有unique的话,会生成一个隐含字段做主键。

innodb中的主键最好是要使用自增id,因为这样当进行插入操作的时候是不需要修改表的存储结构的。

innodb的辅助索引key是辅助索引,而value则是主键。那么这样的话,innodb中主键如果是md5之类的字符串的话,,那么每个辅助索引的磁盘空间就占用很大,而且也有前一条的问题,当插入操作的时候还需要修改表结构。

覆盖索引

由于innodb的辅助索引带主键的机制就导致一种“覆盖索引”的使用。就是只需要在辅助索引中就可以进行到值查找而不需要进行查表。比如一个InnoDB表student字段有uid(主键),username,age。其中建立一个辅助索引username,那么如果你希望查找一个学生名为yejianfeng的学生是否存在:

select id from student where username=”yejianfeng”  (这个查询语句是使用到覆盖索引的,它只会去索引中进行一次查找,而不会查表,当然如果这个表是myisam表的话,就不会覆盖索引了)

select * from student where username=”yejianfeng”  (这个查询是使用不到覆盖索引的,它会去索引查找一次,然后根据主键id去表中再查找一次。所以说不要滥用*)

如知AI笔记 如知AI笔记

如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型

如知AI笔记 27 查看详情 如知AI笔记

索引选择性

索引选择性是建立索引的参考指标,指的是该字段可选择的非重复项在总条数中占的比例。比如说一个表中有100000的条数,有个字段是性别字段,这个性别它只有两个选择,所以它的索引选择性就是2/100000 ~ 0.00002,那么这种情况下,我们就没必要再给这个字段单独加个索引。原因是当选择性太小的话,比如我进行一次查询查出来的100条中有50条是符合查询结果的,相比于选择性大的情况,我进行一次查询查出来的100条中只有5条是符合查询结果的,那么后一种建立索引让索引查询出来的结果变小的效果明显更大。而考虑到索引也占用资源以及增删操作的成本,选择性太小的字段就没有建立索引的必要了。

相关阅读:

MySQL索引之隔离列 

MySQL索引之哈希索引

MySQL索引之前缀索引和索引选择性

MySQL索引使用率监控

MySQL索引优化和in or替换为union all

linux

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 19:21:46
下一篇 2025年11月9日 19:26:51

相关推荐

  • 在 PL/SQL 中绑定变量

    这是 pl/sql 中绑定变量的简单解释: 在 pl/sql 中绑定变量 绑定变量是 sql 语句中的占位符,允许您在运行时传递值,而不是将它们直接硬编码到 sql 查询中。它们对于提高数据库操作的性能和安全性特别有用。 主要特点: 占位符:绑定变量由冒号 (:) 后跟变量名称(例如:dept_id…

    2025年12月19日
    000
  • VARRAY(可变大小数组)- PLSQL 中的集合

    在 pl/sql 中,varray(可变大小数组)是一种可以存储固定数量元素的集合类型。 varray 中的每个元素都是按顺序存储的,并且所有元素的数据类型相同。 varray 的特点: 固定最大大小:定义 varray 时,指定它可以容纳的最大元素数。您不能超过此限制。 顺序:varray 中的元…

    2025年12月19日
    000
  • Oracle SQL 中的解析 |硬解析|软解析

    一般来说,在 Oracle SQL 和数据库中,解析是分解和分析 SQL 语句以确保它们在执行之前在语法和语义上正确的过程。 Oracle SQL 中有两种主要的解析类型:硬解析和软解析。这些决定了数据库处理查询需要做多少工作。 硬解析 定义:当数据库必须从头开始完全解析 SQL 查询时,就会发生硬…

    2025年12月19日
    000
  • PLSQL 中的 DBMS_OUTPUTPUT_LINE

    在 Oracle PL/SQL 中,打印输出的方法是使用 DBMS_OUTPUT.PUT_LINE 过程。该过程将文本写入控制台或输出缓冲区,如果启用了 DBMS_OUTPUT,则可以在执行后查看文本。使用方法如下: 首先,在 SQL 环境(例如 SQL*Plus 或 Oracle SQL Deve…

    2025年12月19日
    000
  • SQL 查询速度慢?使用此技术提高应用程序的性能

    挑战 在我的应用程序(react + spring boot + oracle)中,处理大型数据集导致处理时间极其缓慢。我需要一种解决方案来提高性能而不影响准确性或完整性。 解决方案:ntile + 并行处理 ntile 是一个功能强大的 sql 窗口函数,旨在将结果集划分为指定数量的大致相等大小的…

    2025年12月19日
    000
  • 揭秘合并排序:分治排序初学者指南

    归并排序由约翰·冯·诺依曼于 1945 年提出,主要是为了提高大型数据集的排序效率。冯·诺依曼的算法旨在使用分而治之的方法提供一致且可预测的排序过程。这种策略允许归并排序有效地处理小型和大型数据集,保证在所有情况下都能实现稳定的排序,时间复杂度为 o(n log n)。 合并排序采用分而治之方法,将…

    2025年12月19日
    000
  • c++如何用C++写一个简单的数据库系统_c++ SQLite架构解析与实现【项目】

    推荐用C++封装SQLite而非从零手写数据库,因其已实现ACID、B+树索引、WAL日志等工业级特性;C++只需RAII管理句柄与语句、封装查询/事务接口、统一错误处理,即可高效构建安全易用的数据层。 直接用 C++ 从零写一个工业级数据库系统(如支持 SQL、事务、并发、持久化、索引等)极其复杂…

    2025年12月19日
    000
  • c++如何实现一个简单的B树_c++数据库与文件系统核心数据结构

    B树是一种自平衡多路搜索树,用于数据库和文件系统中高效管理磁盘I/O。1. 每个节点可含多个关键字和子节点指针,根节点至少两子节点(非叶子),所有叶子同层。2. 节点关键字数在t-1到2t-1之间,内部节点最多2t子节点,t为最小度数。3. 使用模板类实现节点结构,固定数组模拟磁盘块,支持泛型键值。…

    2025年12月19日
    000
  • C++简易数据库 文件存储查询系统

    答案:用C++实现简易数据库需设计结构体并以二进制形式存入文件,支持增删改查。1. 定义Student结构体存储学生信息;2. 使用fstream以二进制模式读写文件;3. 增加记录时追加到文件末尾;4. 查询时遍历文件匹配id或姓名;5. 修改时用seekp定位并重写数据;6. 删除可用标记法或重…

    2025年12月18日
    000
  • C++框架内置功能在跨平台开发中的作用

    在跨平台开发中,c++++ 框架的内置功能发挥着至关重要的作用,包括:跨平台兼容性:在多平台上稳定运行,简化移植。图形用户界面 (gui) 支持:提供跨平台的 gui 库,无需编写平台特定代码。数据库集成:支持多种数据库系统,实现数据访问和操作的跨平台性。网络通信:提供网络通信机制,用于分布式应用程…

    2025年12月18日
    000
  • 将C++框架与数据库技术集成时有哪些注意事项?

    集成 c++++ 框架和数据库技术需要考虑以下事项:使用连接池以减少数据库连接的开销。利用持久性框架,如 hibernate 或 qt sql,来简化数据库交互。确保 c++ 数据类型与数据库数据类型正确映射。通过事务处理确保多数据库操作的原子性和一致性。采取安全措施,如参数化查询和数据验证,以防止…

    2025年12月18日
    000
  • C++ 框架设计中实现代码重用的技术

    在 c++++ 框架设计中,实现代码重用的技术包括:模板方法模式:定义算法大纲,由子类定义具体步骤。策略模式:分离算法实现和使用对象,提高灵活性。工厂方法模式:创建对象的方法由子类实现,允许创建不同类型对象。抽象工厂模式:创建相关对象家族的方法,无需指定具体类,促进松耦合。单例模式:确保类只有一个实…

    2025年12月18日
    100
  • C#如何进行数据库分片 ShardingSphere-Proxy .NET客户端用法

    ShardingSphere-Proxy 作为兼容 MySQL/PostgreSQL 协议的透明代理,.NET 应用只需使用 MySqlConnector 或 Npgsql 等标准 ADO.NET 驱动连接其地址(如 127.0.0.1:3307),即可透明执行分片路由,无需官方 SDK 或修改业务…

    2025年12月17日
    000
  • C#开发者需要掌握哪些数据库知识?SQL Server与C#开发核心技能点梳理

    C#开发者需掌握SQL Server核心技能,包括熟练编写CRUD语句、理解索引与执行计划、使用ADO.NET和Entity Framework进行安全高效的数据交互,并具备数据库设计协作能力,确保应用性能与稳定性。 对于C#开发者而言,数据库不仅是数据存储的工具,更是应用系统的核心组成部分。掌握必…

    2025年12月17日
    000
  • .NET中的LINQ to SQL和LINQ to Entities有什么区别?为什么EF Core是未来的方向?

    LINQ to SQL是专为SQL Server设计的轻量级ORM,简单高效但功能有限;1. LINQ to Entities作为Entity Framework的一部分,支持多数据库、复杂映射和模型优先开发,更具灵活性;2. EF Core是现代数据访问技术,跨平台、高性能、支持NoSQL,集成最…

    2025年12月17日
    000
  • C# 怎么连接 MySQL 数据库_C# MySQL 数据库连接配置指南

    首先安装MySql.Data驱动并引入命名空间,然后配置包含服务器、用户、密码等信息的连接字符串,通过MySqlConnection类尝试连接,最后使用try-catch处理异常确保连接稳定。 在 C# 中连接 MySQL 数据库,需要使用合适的驱动程序并正确配置连接字符串。下面详细介绍如何配置和实…

    2025年12月17日
    000
  • 什么是NuGet包?如何用它安装数据库相关库?

    使用NuGet可轻松安装数据库库,如在Visual Studio中右键项目选择“管理NuGet程序包”搜索并安装对应库,或通过Package Manager Console执行Install-Package命令,也可用.NET CLI在终端运行dotnet add package命令添加,安装后自动…

    2025年12月17日
    000
  • 什么是数据库快照?在C#中如何用它进行数据恢复?

    数据库快照是只读静态视图,利用稀疏文件和写时复制机制捕获特定时间点的数据状态,创建时速度快且占用空间小,通过记录原始数据页变化实现快速恢复。在C#中通过执行T-SQL命令创建和恢复快照,适用于防止人为错误或测试回滚,但不替代备份,仅支持SQL Server Enterprise版,恢复时会阻塞应用并…

    2025年12月17日
    000
  • C#中如何监控数据库的长时间运行查询?如何终止?

    首先通过查询SQL Server的动态管理视图sys.dm_exec_requests识别长时间运行的查询,再结合C#定时轮询与KILL命令终止会话。1. 使用SqlConnection执行SQL查询获取运行超过30秒的请求,包含SPID、命令、持续时间及SQL文本;2. 发现超时查询后调用KILL…

    2025年12月17日
    000
  • 如何用C#实现数据库的分布式事务?需要什么支持?

    使用TransactionScope可实现C#中跨数据库的分布式事务,依赖MSDTC服务协调两阶段提交,需确保数据库支持XA协议、网络配置正确,并注意性能开销与平台限制,在.NET Core跨平台场景宜采用Saga或最终一致性等替代方案。 在C#中实现数据库的分布式事务,主要依赖于 System.T…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信