数据库教程:mysql如何优化插入记录速度

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

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

一. 对于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如何优化插入记录速度的全部内容,希望数据库技术:mysql如何优化插入记录速度的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持<计算机技术网(www.ctvol.com)!!>!

需要了解更多数据库技术:mysql如何优化插入记录速度,都可以关注数据库技术分享栏目—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/612786.html

(0)
上一篇 2021年5月19日
下一篇 2021年5月19日

精彩推荐