失效链接处理 |
MySQL 5.7 批量写入性能测试对比 PDF 下载
本站整理下载:
相关截图:
主要内容:
一. 大纲
本篇主要探究数据交换场景下,如何从表结构、索引、数据形态等方面有效的提升批量写入MySQL的性能。
个人列了几点会影响写入性能的因素,然后实际通过测试验证下:
1.one_value vs multiple_value
2.事务大小对写入的影响
3.随机主键 vs 顺序主键
4.二级索引对写入性能的影响
5.B+数高度对写入性能的影响
测试环境:MySQL版本(5.7.27-log ),存储为SSD,用python脚本生成数据进行批量写入性能测试。
这里测试环境默认均为双1模式,也不考虑双1模式对于写入性能的影响。
二. one_value vs multiple_value
测试表包含自增主键与3个varchar字段,varchar字段用随机生成的uuid值填充。
+-------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+----------------+
| a | varchar(50) | NO | | NULL | |
| b | varchar(50) | YES | | NULL | |
| c | varchar(50) | YES | | NULL | |
| d | int(11) | NO | PRI | NULL | auto_increment |
+-------+-------------+------+-----+---------+----------------+
one_value:一条INSERT只包含一个value值,1万条SQL提交一次,总计一个事务包含1w条数据。
multiple_value:一条INSERT包含一万个value值,一条SQL提交一次,总计一个事务包含1w条数据。
|