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

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

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

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

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

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

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

主键:1 - 10 毫秒

唯一索引:10 - 100 毫秒

非唯一索引:100 - 1000 毫秒

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

相关推荐
TT哇1 分钟前
@AllArgsConstructor
java·开发语言
lkbhua莱克瓦241 分钟前
TCP通信练习1——多发多收
java·开发语言·网络·网络协议·tcp/ip·tcp练习
这就是佬们吗2 分钟前
一文讲清---ELK搭建
java·笔记·elk·docker·容器
Filotimo_3 分钟前
在java后端开发中,docker虚拟化容器用处
java·开发语言·docker
大学生资源网5 分钟前
基于springboot的智能家居系统的设计与实现(源码+文档)
java·spring boot·后端·毕业设计·源码
葵花楹5 分钟前
Maven 核心能力拆解 + 实战: Java 邮件群发
java·maven
Java程序员-小白6 分钟前
使用Docker安装MySQL
mysql·docker·容器
洛阳纸贵7 分钟前
JAVA高级工程师--Maven父子关系专题
java·前端·maven
和光同尘20238 分钟前
一文讲透CentOS下安装部署使用MYSQL
linux·运维·数据库·数据仓库·mysql·centos·database
爱干饭的boy13 分钟前
MacBook安装node.js/maven/mysql
mysql·node.js·maven