架构设计 - MySQL 插入数据性能优化策略

mysql 数据库提高数据插入效率主要可以考虑以下方面:

  • 使用批量插入数据的 SQL 语句,避免使用 for 循环逐条记录插入。

  • 所有插入语句共用一个事务,避免1条SQL语句开1个事务,所有操作都完成后再提交事务。

  • 尽量按照索引递增顺序插入记录,以避免频繁的调整索引。

  • 控制事务大小。插入的数据量不要超过 innodb_log_buffer_size 配置属性的值,超过这个值会导致 InnoDB 把数据刷到磁盘中,进而影响插入效率。如果数据量太大,可以将大数据插入操作拆分成多个较小的事务。

MySQL 的数据 CRUD 操作性能指标:(以千万级别数据为例)

主键:1 - 10 毫秒

唯一索引:10 - 100 毫秒

非唯一索引:100 - 1000 毫秒

无索引:百万条数据 1000+ 毫秒

相关推荐
懒羊羊不懒@3 分钟前
JavaSe—集合框架、Collection集合
java·开发语言
ss2736 分钟前
Springboot + vue 医院管理系统
vue.js·spring boot·后端
霸道流氓气质8 分钟前
Java中Stream使用示例-对实体List分组且保留原数据顺序并对分组后的每组内的数据进行部分业务逻辑修改操作
java·list
java1234_小锋41 分钟前
Spring事件监听的核心机制是什么?
java·spring·面试
星释1 小时前
Rust 练习册 16:Trait 作为返回类型
java·网络·rust
2301_796512521 小时前
Rust编程学习 - 如何理解Rust 语言提供了所有权、默认move 语义、借用、生命周期、内部可变性
java·学习·rust
乐悠小码1 小时前
Java设计模式精讲---03建造者模式
java·设计模式·建造者模式
一个人的幽默1 小时前
聊一下java获取客户的ip
java
披着羊皮不是狼2 小时前
Spring Boot——从零开始写一个接口:项目构建 + 分层实战
java·spring boot·后端·分层
小白银子2 小时前
零基础从头教学Linux(Day 60)
linux·数据库·mysql·oracle