加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql如何优化插入记录速度 优就业

发布时间:2020-12-12 03:04:28 所属栏目:MySql教程 来源:网络整理
导读:《mysql如何优化插入记录速度 优就业》要点: 本文介绍了mysql如何优化插入记录速度 优就业,希望对您有用。如果有疑问,可以联系我们。 插入记录时,影响插入速度的主要是索引、唯一性校验、一次插入记录条数等.根据这些情况,可以分别进行优化,本节将介绍优

《mysql如何优化插入记录速度 优就业》要点:
本文介绍了mysql如何优化插入记录速度 优就业,希望对您有用。如果有疑问,可以联系我们。

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

一.对于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语句快.

mysql如何优化插入记录速度 优就业

Java开发:http://www.ujiuye.com/zt/java/

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

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

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

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

更多Java常识尽在优就业IT培训:www.ujiuye.com

欢迎参与《mysql如何优化插入记录速度 优就业》讨论,分享您的想法,编程之家PHP学院为您提供专业教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读