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

Mysql的索引,慢查询和数据库表的设计以及乐观锁和悲观锁

设计高性能数据表的原则

数据库设计经验和技巧

  • 单张数据表的字段不宜过多(20个),如果确实存在大量field,考虑拆成多张表或json text存储

  • 数据表字段都是not null的,即使没有数据,最好也使用无意义的值填充,并在业务代码中特殊处理

  • 索引不应该过多(6个),且是随着业务迭代逐步的修改与优化

  • 不追求严格的数据精简(灵活调整),通过字段冗余来优化查询,减少表关联

索引的优化

索引的类型和匹配原则(InnoDB)

主键索引和辅助索引

辅助索引的叶子节点存储的是主键值

索引匹配原则

  • 索引遵循【最左前缀匹配原则】(针对于多列索引,或者叫联合索引);但是要注意索引字段的顺序

  • 触发索引覆盖,不需要回表,速度最优

  • 善于使用explain,desc分析执行计划

合理使用乐观锁和悲观锁

实现乐观锁的三种方法
  • 使用数据版本,更新之前对比version是否相同

  • 使用时间戳,和version的实现方式类似,更新之前对比时间戳是否相同

  • 使用特定的业务字段(例如库存值),更新数据时检查字段值是否满足预期

第一种和第二种在高并发的时候只有一个线程可以修改成功,存在大量的失败,吞吐率不高,第三种降低了乐观锁的粒度,只需要保证salary满足条件即可,提高了并发能力

实现悲观锁的方法与注意事项
  • 要想使用悲观锁,那么必须关闭MySQL的自动提交

  • 实现悲观锁的语法:select ... for update(MySQL InnoDB默认是Row-Level Lock(行锁))

  • 扩展:select...Lock in share mode (共享锁)

慢查询

Mysql默认不开启慢查询(效率损耗)

慢查询危害

  • 会将暴露出去的http接口拖慢、

  • 慢查询存在往往会消耗更多的CPU和内存,影响数据库的整体性能

  • 很多慢查询是由于行锁升级到表锁导致的,由此会造成DDL操作的阻塞

慢查询常见的场景与优化策略

  • 查询字段没有加索引,或没有利用好索引,由此引发了全表扫描

    • 解决思路:利用explain和desc命令查看

  • 单表数据量太大,普通查询或limit深分页较慢

    • 解决思路:在业务层面进行考虑

  • 使用FileSort查询(order by)(排序字段没有加索引, 使用多字段排序,但是排序规则不同)

    • 如果查询数据较少,没有超过系统的变量sort_buffer_size时候,则直接在内存中进行排序,是快排,如果超过了变量大小,则会用文件进行排序,也就是归并排序,会导致特别慢,因为涉及到磁盘间文件交换

http://www.xdnf.cn/news/5829.html

相关文章:

  • AUTOSAR图解==>AUTOSAR_TR_GeneralBlueprintsSupplement
  • 知网AI检测对抗智能体,降AI率不再单独花钱!
  • ESP32 web服务导致的lwip “pbuf_free: p->ref > 0问题
  • 【001】renPy android端启动流程分析
  • 内存对齐(Memory Alignment)
  • 4399(简易版) GOC小游戏
  • [python] 面向对象的三大特性-封装及新式类
  • Autoregressive Distillation of Diffusion Transformers
  • IOP|2025第二届机电一体化、机器人与控制系统国际会议(MRCS2025)
  • 电流互感器使用全攻略
  • Hugging Face汉化教程及注册使用详解
  • python-74-Nacos技术之单机模式安装Nacos并使用Python操作Nacos
  • 【Ansible】之inventory主机清单
  • 用 openssl 测试 tls 连接
  • Redis+Caffeine构造多级缓存
  • 多模态链式思考推理:让大模型更像人类一样思考
  • C——五子棋小游戏
  • 互联网大厂Java求职面试:优惠券服务架构设计与AI增强实践-3
  • cursor 出现问题 为客户解决问题
  • 大模型科研能力评价参考平台上线,推动技术创新与发展
  • Koa知识框架
  • 机器学习——集成学习基础
  • 信息安全模型全解:从机密性到完整性的理论基石
  • Scala安装教程
  • 通用RAG:通过路由模块对多源异构知识库检索生成问答思路
  • C++ asio网络编程(5)简单异步echo服务器
  • 自动发电控制是一次调频还是二次调频?
  • 运行Spark程序(二)RDD基本概念和创建
  • 【Vue】Composables 和 Utils 区别
  • SysAid On-Prem XML注入漏洞复现(CVE-2025-2776)