当前位置: 首页 > 图文教程 > 数据库 > MYSQL > 5种方法优化MySQL插入表格查询

MYSQL
MS SQL大值数据类型varchar(max)、nvarchar(max)、varbinary(max)
MySQL索引经验之浅见
提高MySQL 查询效率的三个技巧(1)
提高MySQL 查询效率的三个技巧(2)
提高MySQL 查询效率的三个技巧(3)
MySQL中的mysqldump命令使用详解
Linux下mysql的C API简单使用
MYSQL 有条件地插入记录
mysql 注释方法
MySQL备份--使用mysqldump全备
Mysql索引
5种方法优化MySQL插入表格查询
java实现插入mysql二进制文件,blob类型,遇到问题及解决办法
mysql中root用户的密码修改和消除
完全优化MySQL数据库性能的八大巧方法
MySQL与标准的兼容性
优化MYSQL服务器
MYSQL 权限
Mysql 基本用法
Mysql 备份与恢复

MYSQL 中的 5种方法优化MySQL插入表格查询


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 160 ::
收藏到网摘: n/a

1)使用LOAD DATA INFILE从文本下载数据这将比使用插入语句快20倍。

2)使用带有多个VALUES列表的INSERT语句一次插入几行这将比使用一个单行插入语句快几倍。调整bulk_insert_buffer_size变量也能提高(向包含行的表格中)插入的速度。

3)可以对myisam表并行插入Concurrent_insert系统变量可以被设置用于修改concurrent-insert处理。该变量默认设置为1。如果concurrent_insert被设置为0,并行插入就被禁用。如果该变量被设置为2,在表的末端可以并行插入,即便该表的某些行已经被删除。

4)使用插入延迟

如果你的客户不能或无需等待插入完成的时候,这招很有用。当你使用MySQL存储,并定期运行需要很长时间才能完成的SELECT和UPDATE语句的时候,你会发现这种情况很常见。当客户使用插入延迟,服务器立刻返回,如果表没有被其他线程调用,则行会列队等待被插入。使用插入延迟的另一个好处就是从多个客户插入的情况会被绑定并记录在同一个block中。这将比处理多个独立的插入要快得多。

5)插入之前将表锁定(只针对非事务处理型的表)

这将提高数据库性能,因为索引缓冲区只是在所有的插入语句完成后才对磁盘进行一次刷新。通常情况下,有多少个插入语句就会有多少次索引缓冲区刷新。如果你可以用一个插入语句实现所有行的插入,则无需使用显式锁定语句。

要想更快地对事务型表插入,你应该使用START TRANSACTION和COMMIT语句,而不是LOCK TABLES语句。