mysql如何优化插入记录速度

作者:落叶的博客 时间:2024-01-29 07:44:35 

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

一. 对于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。

来源:http://www.cnblogs.com/wangyayun/p/6525406.html

标签:mysql,优化
0
投稿

猜你喜欢

  • SQL Server ISNULL 不生效原因及解决

    2024-01-13 09:53:34
  • ASP经常用到的函数

    2009-07-06 13:00:00
  • oracle初始化参数设置

    2010-07-31 12:47:00
  • SQL Server正则表达式 替换函数应用详解

    2023-07-07 23:53:13
  • python实现处理mysql结果输出方式

    2024-01-28 03:30:42
  • Win7下Python与Tensorflow-CPU版开发环境的安装与配置过程

    2022-02-22 07:34:22
  • python机器学习理论与实战(四)逻辑回归

    2021-07-19 21:05:12
  • 利用Python将社交网络进行可视化

    2022-12-18 07:07:15
  • Python代码实现删除一个list里面重复元素的方法

    2022-06-02 15:31:02
  • Python MySQLdb 使用utf-8 编码插入中文数据问题

    2023-07-31 11:04:13
  • JavaScript设计模式之享元模式实例详解

    2024-04-17 10:08:34
  • 在IPython中执行Python程序文件的示例

    2023-02-20 09:06:14
  • 详解JavaScript基于面向对象之继承

    2024-04-29 13:23:06
  • 微信公众号开发之获取位置信息php代码

    2023-11-17 06:33:15
  • ASP简单实现数字和字母验证码

    2008-10-23 13:52:00
  • PHP实现简单注册登录系统

    2024-05-02 17:34:13
  • python迭代器自定义类的具体方法

    2023-07-08 06:17:30
  • Python使用PyAV提取视频关键帧的实践

    2023-04-29 23:45:04
  • pandas取出重复数据的方法

    2021-03-23 09:12:52
  • python中字符串的编码与解码详析

    2022-11-15 23:24:12
  • asp之家 网络编程 m.aspxhome.com