Mysql大量插入数据时SQL语句的优化
来源:互联网 发布:手机串行端口 编辑:程序博客网 时间:2024/04/29 20:15
1) 对于Myisam类型的表,可以通过以下方式快速的导入大量的数据。
ALTER TABLE tblname DISABLE KEYS;
loading the data
ALTER TABLE tblname ENABLE KEYS;
这两个命令用来打开或者关闭Myisam表非唯一索引的更新。在导入大量的数据到一个非空的Myisam表时,通过设置这两个命令,可以提高导入的效率。对于导入大量数据到一个空的Myisam表,默认就是先导入数据然后才创建索引的,所以不用进行设置。
而对于Innodb类型的表,这种方式并不能提高导入数据的效率。
2) 对于Innodb类型的表,我们有以下几种方式可以提高导入的效率:
ALTER TABLE tblname DISABLE KEYS;
loading the data
ALTER TABLE tblname ENABLE KEYS;
这两个命令用来打开或者关闭Myisam表非唯一索引的更新。在导入大量的数据到一个非空的Myisam表时,通过设置这两个命令,可以提高导入的效率。对于导入大量数据到一个空的Myisam表,默认就是先导入数据然后才创建索引的,所以不用进行设置。
而对于Innodb类型的表,这种方式并不能提高导入数据的效率。
2) 对于Innodb类型的表,我们有以下几种方式可以提高导入的效率:
- 因为Innodb类型的表是按照主键的顺序保存的,所以将导入的数据按照主键的顺序排列,可以有效的提高导入数据的效率。如果Innodb表没有主键,那么系统会默认创建一个内部列作为主键,所以如果可以给表创建一个主键,将可以利用这个优势提高导入数据的效率。
- 在导入数据前执行SET UNIQUE_CHECKS=0,关闭唯一性校验,在导入结束后执行SET UNIQUE_CHECKS=1,恢复唯一性校验,可以提高导入的效率。
- 如果应用使用自动提交的方式,建议在导入前执行SET AUTOCOMMIT=0,关闭自动提交,导入结束后再执行SET AUTOCOMMIT=1,打开自动提交,也可以提高导入的效率。
0 0
- Mysql大量插入数据时SQL语句的优化
- Mysql大量插入数据时SQL语句的优化
- 大批量插入数据时优化SQL语句
- sqlite大量数据插入的优化
- mysql插入大量数据
- Mysql插入大量数据
- mysql 插入大量数据
- mysql大量插入数据的方法
- 一条SQL语句插入大量数据 和查看某个表的字段是否有重复值
- sql 大量数据查询的 优化措施
- SQL大量数据查询的优化
- SQL大量数据查询的优化
- SQL大量数据查询的优化
- SQL大量数据查询的优化
- SQL大量数据查询的优化
- SQL一次性插入大量数据
- SQL循环插入大量数据
- mysql快速插入大量数据
- 阿里云 Linux CentOS ip设置相关
- iOS第三方资源
- 博客搬家
- shiro表单登录认证及退出(自定义form认证器)
- 百度地图API
- Mysql大量插入数据时SQL语句的优化
- dede源码详细分析之--全局变量覆盖漏洞的防御
- android 自定义控件学习之三 控件布局常用知识总结
- 图像处理算法——卷积
- 容器集群管理的武林大比
- iOS 常用的框架
- Android中shape的使用
- linux 部署tomcat
- Arrays.sort()总结