当前位置: 首页 > news >正文

MySQL索引和事务笔记

文章目录

    • 一、索引
      • 1. 索引是什么?
      • 2. 索引的优缺点
        • 优点
        • 缺点
      • 3. 索引的操作
      • 4. 索引背后的数据结构
      • 5. 面试高频问题
    • 二、事务
      • 1. 事务的作用
      • 2. 事务的实现机制
      • 3. 事务的基本操作
      • 4. 事务的四大特性(ACID)
      • 5. 并发事务常见问题
      • 6. 事务隔离级别
    • 三、总结与建议

一、索引

1. 索引是什么?

  • 类似于书的目录(Index),用于加速查询。
  • 查询时默认全表遍历,复杂度 O(N),每行需硬盘读取,效率低。
  • 索引通过特殊数据结构(如B+树)提升查询速度。

2. 索引的优缺点

优点
  • 显著提升查询效率,特别是大数据量场景。
  • 查询频率高于增删改的业务场景下尤为合适。
缺点
  • 占用额外存储空间。
  • 增删改操作时需同步维护索引,可能影响写入性能。

3. 索引的操作

  • 查看索引
    show index from 表名;
    主键、唯一键(unique)、外键(foreign key)都会自动生成索引。

  • 创建索引
    create index 索引名 on 表名(列名);
    注意:大表上创建索引是危险操作,可能导致大量IO,建议提前规划。

  • 删除索引
    drop index 索引名 on 表名;
    只能删除自建索引,不能删除自动生成的主键/唯一索引。

4. 索引背后的数据结构

  • 二叉搜索树
    高度大、IO次数多,不适合数据库索引。

  • 哈希表
    只支持等值查询,不支持范围和模糊查询。

  • B+树(主流索引结构)

    • N叉搜索树,树高度低,减少硬盘IO。
    • 叶子节点存储所有数据,并通过链表连接,方便范围查询。
    • 查询都落在叶子节点,查询开销稳定。
    • 非叶子节点只存key,不存数据,空间占用小。
    • 适合数据库大规模数据的高效检索。

5. 面试高频问题

  • 索引是什么?解决了什么问题?
  • 索引的代价(空间、写入性能)。
  • 如何操作索引?注意事项?
  • 索引的数据结构及B+树的优势。

二、事务

1. 事务的作用

  • 保证一组SQL操作的原子性,要么全部执行,要么全部不执行(回滚)。
  • 典型场景:银行转账,防止只转出未转入。

2. 事务的实现机制

  • 数据库通过日志体系记录每一步操作,支持回滚和崩溃恢复。
  • 不是所有操作都能回滚(如drop database)。
  • 事务操作应尽量简短,避免长事务。

3. 事务的基本操作

  • 开启事务:start transaction;
  • 提交事务:commit;
  • 回滚事务:rollback;

4. 事务的四大特性(ACID)

  1. 原子性(Atomicity)
    要么全部执行,要么全部不执行。

  2. 一致性(Consistency)
    事务前后,数据都处于合法状态。

  3. 持久性(Durability)
    事务提交后,数据永久保存在硬盘。

  4. 隔离性(Isolation)
    并发事务间互不干扰,避免相互影响。

5. 并发事务常见问题

  • 脏读
    一个事务读取到另一个未提交事务的数据。

  • 不可重复读
    同一事务内多次读取,数据被其他已提交事务修改,导致结果不一致。

  • 幻读
    一事务多次查询,期间其他事务插入/删除了数据,导致结果集数量不同。

6. 事务隔离级别

隔离级别脏读不可重复读幻读并发性说明
read uncommitted最高可读未提交数据,最不安全
read committed较高只读已提交数据
repeatable read较低读写都加锁,MySQL默认级别
serializable最低串行执行,最安全最慢

三、总结与建议

  • 索引是提升查询性能的利器,但需权衡空间和写入性能。
  • B+树是数据库索引的核心结构,掌握其原理有助于面试答题和实际优化。
  • 事务保证数据可靠性,理解ACID和隔离级别是数据库开发的基础。
  • 索引和事务都需结合实际业务场景合理使用,避免过度依赖或滥用。
http://www.lryc.cn/news/604726.html

相关文章:

  • 开源 Arkts 鸿蒙应用 开发(十三)音频--MP3播放
  • WPFC#超市管理系统(3)商品管理
  • 【科研绘图系列】R语言绘制绝对量柱状堆积图+环形图数量统计+特数量标注
  • 潇洒郎: Kafka Ubuntu 安装部署,命令行或者python生产数据与消费数据(kafka-python)
  • 【选型】HK32L088 与 STM32F0/L0 系列 MCU 参数对比与选型建议(ST 原厂 vs 国产芯片)
  • 2025年6月数据挖掘顶刊TKDE研究热点有哪些?
  • 传输层协议UDP与TCP
  • 周期滤波策略
  • AbMole小课堂丨bFGF(FGF-2):维持干细胞培养、驱动类器官构建与细胞分化
  • 容器与虚拟机的本质差异:从资源隔离到网络存储机制
  • 如何使用 Apache Ignite 作为 Spring 框架的缓存(Spring Cache)后端
  • GitPython02-Git使用方式
  • RHCA - CL260 | Day03:配置 RHCS 集群
  • 将 qt 构建为静态库
  • BGP高级特性之正则表达式
  • vue npm install卡住没反应
  • ISO 26262 汽车功能安全(腾讯混元)
  • 在 CentOS 系统上安装 Docker
  • Kotlin -> Kotlin Lambda 表达式与 Function 接口的关系
  • 深入理解 Kotlin Flow:异步数据流处理的艺术
  • 在线教育场景下AI应用,课程视频智能生成大纲演示
  • Jupyter Notebook 中显示图片、音频、视频的方法汇总
  • Python 使用pandas库实现Excel字典码表对照自动化处理
  • C++:STL中list的使用和模拟实现
  • 《C++二叉搜索树原理剖析:从原理到高效实现教学》
  • CH347使用笔记:CH347作为FPGA下载器的几种方式
  • 大语言模型API付费?
  • 【PZ7020-StarLite 入门级开发板】——FPGA 开发的理想起点,入门与工业场景的双重优选
  • PyTorch API
  • PyTorch 生态四件套:从图片、视频到文本、语音的“开箱即用”实践笔记