MySQL: Speed of INSERT Statements
Speed of INSERT Statements
To optimize insert speed, combine many small operations into a single large operation. Ideally, you make a single connection, send the data for many new rows at once, and delay all index updates and consistency checking until the very end.
The time required for inserting a row is determined by the following factors, where the numbers indicate approximate proportions:
- Connecting: (3) 
- Sending query to server: (2) 
- Parsing query: (2) 
- Inserting row: (1 × size of row) 
- Inserting indexes: (1 × number of indexes) 
- Closing: (1) 
This does not take into consideration the initial overhead to open tables, which is done once for each concurrently running query.
The size of the table slows down the insertion of indexes by log N, assuming B-tree indexes.
You can use the following methods to speed up inserts:
- If you are inserting many rows from the same client at the same time, use - INSERTstatements with multiple- VALUESlists to insert several rows at a time. This is considerably faster (many times faster in some cases) than using separate single-row- INSERTstatements. If you are adding data to a nonempty table, you can tune the- bulk_insert_buffer_sizevariable to make data insertion even faster. See Section 5.1.4, “Server System Variables”.
- When loading a table from a text file, use - LOAD DATA INFILE. This is usually 20 times faster than using- INSERTstatements. See Section 13.2.6, “LOAD DATA INFILE Syntax”.
- Take advantage of the fact that columns have default values. Insert values explicitly only when the value to be inserted differs from the default. This reduces the parsing that MySQL must do and improves the insert speed. 
- See Section 8.5.2, “Bulk Data Loading for MyISAM Tables” for tips specific to - MyISAMtables.
REF:
MySQL: Speed of INSERT Statements的更多相关文章
- 8.2.1.1 Speed of SELECT Statements  加速SELECT 语句
		8.2.1 Optimizing SELECT Statements 8.2.2 Optimizing Data Change Statements 8.2.3 Optimizing Database ... 
- mysql 插入重复值  INSERT ... ON DUPLICATE KEY UPDATE
		向数据库插入记录时,有时会有这种需求,当符合某种条件的数据存在时,去修改它,不存在时,则新增,也就是saveOrUpdate操作.这种控制可以放在业务层,也可以放在数据库层,大多数数据库都支持这种需求 ... 
- MySQL中的insert ignore into, replace into等的一些用法小结(转)
		MySQL中的insert ignore into, replace into等的一些用法总结(转) 在MySQL中进行条件插入数据时,可能会用到以下语句,现小结一下.我们先建一个简单的表来作为测试: ... 
- 转载:mysql 操作总结 INSERT和REPLACE
		转自:http://www.jb51.net/article/19411.htm 用于操作数据库的SQL一般分为两种,一种是查询语句,也就是我们所说的SELECT语句,另外一种就是更新语句,也叫做 ... 
- 源码浅析:MySQL一条insert操作,会写哪些文件?包括UNDO相关的文件吗?
		DML操作的大致流程 在解答上述疑惑之前,我们来梳理一下DML操作的大致流程: 1.语法解析.语义解析 2.生成执行计划 3.事务修改阶段 1) 激活事务,事务状态由not_active变为activ ... 
- mysql二进制文件操作语法(mysql binary log operate statements)
		开启 binary logs 功能 在 mysql 配置文件中配置 log-bin,重启 mysql my.cnf (on Linux/unix) or my.ini (on Windows) 例子: ... 
- MySQL中的insert ignore into, replace into等的一些用法总结
		在MySQL中进行条件插入数据时,可能会用到以下语句,现小结一下.我们先建一个简单的表来作为测试: CREATE TABLE `books` ( `id` INT(11) NOT NULL AUTO_ ... 
- mysql错误用法insert into where
		mysql中给表中插入数据,一般使用insert into. 但是在插入数据时,有时会根据条件来插入数据,比如insert into t_person(num,name) values(1,'lily ... 
- MySql中利用insert into select 准备数据uuid主键冲突
		MYSQL 中表1需要准备大量数据,内容主要取自表2,id必须为32位uuid (项目所有表都是这样,没办法), 准备这样插入: INSERT INTO TBL_ONE (ID, SOID, SNAM ... 
随机推荐
- Java Filter过滤xss注入非法参数的方法
			http://blog.csdn.NET/feng_an_qi/article/details/45666813 Java Filter过滤xss注入非法参数的方法 web.xml: <filt ... 
- .Net Ajax跨域请求总结
			导语 之前写过一篇文章Ajax跨域请求COOKIE无法带上的解决办法,这两天正好好好的查了一下相关知识,做来总结一下 一.传统 ajax跨域访问是一个老问题了,解决方法很多,比较常用的是JSONP方法 ... 
- DocumentRoot \
			w 有无\的区别. https://httpd.apache.org/docs/2.4/vhosts/examples.html hosts 127.0.0.1 w.w httpd.conf Ser ... 
- 【转】UML中类与类之间的5种关系表示
			一.继承关系 继承指的是一个类(称为子类.子接口)继承另外的一个类(称为父类.父接口)的功能,并可以增加它自己的新功能的能力.在Java中继承关系通过关键字extends明确标识,在设计时一 ... 
- 【react读取文件】react发送GET请求读取静态文件
			react中,使用发送请求的方式把static文件夹中的前端可访问的静态文件读取成字符串: 1.new request,需要用到getRequestHeaders组件 2.fetch获取respons ... 
- HTTP和HTTPS的请求和响应
			HTTP协议(HyperText Transfer Protocol,超文本传输协议):是一种发布和接收 HTML页面的方法.HTTPS(Hypertext Transfer Protocol ove ... 
- (2.10)备份与还原--利用T-SQL进行备份还原
			常用: /************ 一.数据库备份 ************/ with init,format,stats=1init:覆盖format:格式化备份集stats=1:显示进度条 ST ... 
- JS中将字符串中每个单词的首字母大写化
			今天看到一个帖子,处理js中字符串每个单词的首字母大写. 原贴地址:关于字符串中每个单词的首字母大写化问题 受到启发,自己跟着改写了几个版本如下,请大家指正. 1.for循环: var a = 'Hi ... 
- python学习笔记(十八)网络编程之requests模块
			上篇博客中我们使用python自带的urllib模块去请求一个网站,或者接口,但是urllib模块太麻烦了,传参数的话,都得是bytes类型,返回数据也是bytes类型,还得解码,想直接把返回结果拿出 ... 
- Spring第一弹—-全面阐述Spring及轻重量级容器的划分
			Spring是什么? Spring是一个开源的控制反转(Inversion of Control ,IoC)和面向切面(AOP)的容器框架,它的主要目得是简化企业开发. IOC 控制反转 : 1 ... 
