• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL-SQL性能优化之最有效的办法合龙+事务+有序数据进行INSERT操作效率最快_mysql

mysql 搞代码 7年前 (2018-06-07) 189次浏览 已收录 0个评论

mysql-SQL性能优化之最有效的办法合并+事务+有序数据进行INSERT操作效率最快。

对于一些数据量较大的系统,数据库面临的问题除了查询效率低下,还有就是数据入库时间长。特别像报表系统,每天花费在数据导入上的时间可能会长达几个小时或十几个小时之久。因此,优化数据库插入性能是很有意义的。最有效的办法是:合并+事务+有序数据 进行INSERT操作效率最快。

经过对MySQL innodb的一些性能测试,发现一些可以提高insert效率的方法,供大家参考参考。

1. 一条SQL语句插入多条数据。
常用的插入语句如:

1234INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`) VALUES (‘0’, ‘userid_0’, ‘content_0’, 0);INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`) VALUES (‘1’, ‘userid_1’, ‘content_1’, 1);

修改成:

1 2INSERTINTO`insert_table`(`datetime`,`uid`,`content`,`type`) VALUES(‘0′,’userid_0′,’content_0’,0),(‘1′,’userid_1′,’content_1’,1);

 

修改后的插入操作能够提高程序的插入效率。这里第二种SQL执行效率高的主要原因是合并后日志量(MySQL的binlog和innodb的事务让日志)减少了,降低日志刷盘的数据量和频率,从而提高效率。通过合并SQL语句,同时也能减少SQL语句解析的次数,减少网络传输的IO。
这里提供一些测试对比数据,分别是进行单条数据的导入与转化成一条SQL语句进行导入,分别测试1百、1千、1万条数据记录。
MySQL-SQL性能优化之最有效的办法合龙+事务+有序数据进行INSERT操作效率最快_mysql参考:http://www.2cto.com/database/201606/520871.html

欢迎大家阅读《MySQL-SQL性能优化之最有效的办法合龙+事务+有序数据进行INSERT操作效率最快_mysql》,跪求各位点评,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL-SQL性能优化之最有效的办法合龙+事务+有序数据进行INSERT操作效率最快_mysql
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址