你向 MySQL 插入 100万 条数据用了多久?

运维 数据库运维
MySQL插入数据在写阶段是独占的,但是插入一条数据仍然需要解析、计算、最后才进行写处理,比如要给每一条记录分配自增id,校验主键唯一键属性,或者其他一些逻辑处理,都是需要计算的,所以说多线程能够提高效率。

 

目录

1、多线程插入(单表)

2、多线程插入(多表)

3、预处理SQL

4、多值插入SQL

5、事务(N条提交一次)

多线程插入(单表)

问: 为何对同一个表的插入多线程会比单线程快? 同一时间对一个表的写操作不应该是独占的吗?

答:在数据里做插入操作的时候,整体时间的分配是这样的:

1、多链接耗时 (30%) 

2、多发送query到服务器 (20%) 

3、多解析query (20%) 

4、多插入操作 (10% * 词条数目) 

5、多插入index (10% * Index的数目)

6、多关闭链接 (10%)

从这里可以看出来,真正耗时的不是操作,而是链接,解析的过程。

MySQL插入数据在写阶段是独占的,但是插入一条数据仍然需要解析、计算、最后才进行写处理,比如要给每一条记录分配自增id,校验主键唯一键属性,或者其他一些逻辑处理,都是需要计算的,所以说多线程能够提高效率。

多线程插入(多表)

分区分表后使用多线程插入。

预处理SQL

普通SQL  即使用Statement接口执行SQL

预处理SQL  即使用PreparedStatement接口执行SQL

使用PreparedStatement接口允许数据库预编译SQL语句,以后只需传入参数,避免了数据库每次都编译SQL语句,因此性能更好。

多值插入SQL

普通插入SQL: INSERT INTO TBL_TEST (id) VALUES(1)

多值插入SQL: INSERT INTO TBL_TEST (id) VALUES (1), (2), (3)

使用多值插入SQL,SQL语句的总长度减少,即减少了网络IO,同时也降低了连接次数,数据库一次SQL解析,能够插入多条数据。

事务(N条提交一次)

在一个事务中提交大量INSERT语句可以提高性能。

1、将表的存储引擎修改为myisam 2、将 sql 拼接成字符串,每 1000 条左右提交事务。

  • 执行多条SQL语句,实现数据库事务。  

  • mysql数据库  

  • 多条SQL语句

10w条数据大概用时10s!

责任编辑:张燕妮 来源: 搜云库技术团队
相关推荐

2024-04-15 08:30:53

MySQLORM框架

2021-11-02 14:46:50

数据

2010-06-09 11:22:06

MySQL datet

2010-06-02 15:17:07

MySQL datet

2019-04-11 18:46:22

APP手机应用下载

2009-08-12 16:39:50

C#向Excel插入数

2020-01-15 09:53:59

MySQL缓存索引

2023-11-01 21:45:59

数据库MySQL单表

2022-09-23 09:44:17

MyBatisforeach

2020-04-24 21:41:45

MySQL数据库插入数据

2009-07-20 17:03:55

批量插入数据ASP.NET

2020-09-18 10:18:08

MySQL数据插入数据库

2014-11-18 15:59:35

FreeBSD

2023-09-24 14:39:10

MySQLPostgreSQL

2019-05-05 09:28:59

架构数据查询

2019-07-29 14:40:26

架构存储检索

2017-01-19 18:20:59

数据架构数据库

2021-04-08 10:55:53

MySQL数据库代码

2011-05-26 09:01:32

2011-12-16 21:31:47

Kindle
点赞
收藏

51CTO技术栈公众号