主页 > 知识库 > mysql如何优化插入记录速度

mysql如何优化插入记录速度

热门标签:家庭农场地图标注名称怎样起名 互联网电话外呼系统 400电话办理泰安 我要地图标注数量有限制吗 千呼电话机器人可以试用吗 电销需要外呼系统吗 安卡拉地图标注app 电话机器人怎么代理商 零成本地图标注赚钱

插入记录时,影响插入速度的主要是索引、唯一性校验、一次插入记录条数等。根据这些情况,可以分别进行优化,本节将介绍优化插入记录速度的几种方法。

一. 对于MyISAM引擎表常见的优化方法如下:

1. 禁用索引。对于非空表插入记录时,MySQL会根据表的索引对插入记录建立索引。如果插入大量数据,建立索引会降低插入记录的速度。为了解决这种情况可以在插入记录之前禁用索引,数据插入完毕后在开启索引。禁用索引的语句为: ALTER TABLE tb_name DISABLE KEYS;  重新开启索引的语句为: ALTER TABLE table_name ENABLE KEYS; 对于空表批量导入数据,则不需要进行此操作,因为MyISAM引擎的表是在导入数据之后才建立索引的。    

2. 禁用唯一性检查:数据插入时,MySQL会对插入的记录进行唯一性校验。这种唯一性校验也会降低插入记录的速度。为了降低这种情况对查询速度的影响,可以在插入记录之前禁用唯一性检查,等到记录插入完毕之后再开启。禁用唯一性检查的语句为: SET UNIQUE_CHECKS=0; 开启唯一性检查的语句为: SET UNIQUE_CHECKS=1;    

3. 使用批量插入。使用一条INSERT语句插入多条记录。如 INSERT INTO table_name VALUES(....),(....),(....)    

4. 使用LOAD DATA INFILE批量导入当需要批量导入数据时,使用LOAD DATA INFILE语句导入数据的速度比INSERT语句快。

二. 对于InnoDB引擎的表,常见的优化方法如下:

 1. 禁用唯一性检查。同MyISAM引擎相同,通过 SET UNIQUE_CHECKS=0;  导入数据之后将该值置1。   

 2. 禁用外键检查。插入数据之前执行禁止对外键的查询,数据插入完成之后再恢复对外键的检查。禁用外键检查语句为: SET FOREIGN_KEY_CHECKS=0;  恢复对外键的检查语句为: SET FOREIGN_KEY_CHECKS=1;

 3. 禁止自动提交。插入数据之前禁止事务的自动提交,数据导入完成之后,执行恢复自动提交操作。禁止自动提交语句为: SET AUTOCOMMIT=0;  恢复自动提交只需将该值置1。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

您可能感兴趣的文章:
  • MySQL 4G内存服务器配置优化
  • MYSQL开发性能研究之批量插入数据的优化方法
  • Mysql中基本语句优化的十个原则小结
  • mysql处理海量数据时的一些优化查询速度方法
  • Mysql占用过高CPU时的优化手段(必看)
  • MySQL优化之缓存优化
  • MySQL优化之InnoDB优化
  • 简单谈谈MySQL优化利器-慢查询
  • 优化 MySQL 3 个简单的小调整

标签:文山 大同 来宾 池州 东营 新乡 滨州 黄山

巨人网络通讯声明:本文标题《mysql如何优化插入记录速度》,本文关键词  mysql,如何,优化,插入,记录,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《mysql如何优化插入记录速度》相关的同类信息!
  • 本页收集关于mysql如何优化插入记录速度的相关信息资讯供网民参考!
  • 推荐文章