TechTarget中国网站推荐

循序渐进讲解MySQL数据库的性能调整

2008-6-19  选择字号:  | |
打印本文章

  MySQL的性能调整:

  insert查询的速度:

  插入一个记录的时间由下列组成:

  连接:(3)

  发送查询给服务器:(2)

  分析查询:(2)

  插入记录:(1 x 记录大小)

  插入索引:(1 x 索引)

  关闭:(1)

  这里的数字有点与总体时间成正比。这不考虑打开表的初始开销(它为每个并发运行的查询做一次)。

  表的大小以N log N (B 树)的速度减慢索引的插入。

  加快插入的一些方法:

  如果你同时从同一客户插入很多行,使用多个值表的insert语句。这比使用分开insert语句快(在一些情况中几倍)。

  如果你从不同客户插入很多行,你能通过使用insert DELAYED语句得到更高的速度。

  注意,用MyISAM,如果在表中没有删除的行,能在select:s正在运行的同时插入行。

  当从一个文本文件装载一个表时,使用LOAD DATA INFILE。这通常比使用很多insert语句快20倍。当表有很多索引时,有可能多做些工作使得LOAD DATA INFILE更快些。使用下列过程:

  有选择地用create TABLE创建表。例如使用mysql或Perl-DBI。

  执行FLUSH TABLES,或外壳命令mysqladmin flush-tables。

  使用myisamchk --keys-used=0 -rq /path/to/db/tbl_name。这将从表中删除所有索引的使用。

  用LOAD DATA INFILE把数据插入到表中,这将不更新任何索引,因此很快。

  如果你有myisampack并且想要压缩表,在它上面运行myisampack.

  用myisamchk -r -q /path/to/db/tbl_name再创建索引。这将在将它写入磁盘前在内存中创建索引树,并且它更快,因为避免大量磁盘寻道。结果索引树也被完美地平衡。

  执行FLUSH TABLES,或外壳命令mysqladmin flush-tables。

  这个过程将被构造进在MySQL的某个未来版本的LOAD DATA INFILE。

  你可以锁定你的表以加速插入。

  mysql> LOCK TABLES a WRITE;mysql> insert INTO a VALUES (1,23),(2,34),(4,33);mysql> insert INTO a VALUES (8,26),(6,29);mysql> UNLOCK TABLES;主要的速度差别是索引缓冲区仅被清洗到磁盘上一次,在所有insert语句完成后。一般有与有不同的insert语句那样夺的索引缓冲区清洗。如果你能用一个单个语句插入所有的行,锁定就不需要。锁定也将降低多连接测试的整体时间,但是对某些线程最大等待时间将上升(因为他们等待锁)。例如:

  thread 1 does 1000 insertsthread 2, 3, and 4 does 1 insert

  thread 5 does 1000 inserts如果你不使用锁定,2、3和4将在1和5前完成。如果你使用锁定,2、3和4将可能不在1或5前完成,但是整体时间应该快大约40%。因为insert, update和delete操作在MySQL中是很快的,通过为多于大约5次连续不断地插入或更新一行的东西加锁,你将获得更好的整体性能。如果你做很多一行的插入,你可以做一个LOCK TABLES,偶尔随后做一个UNLOCK TABLES(大约每1000行)以允许另外的线程存取表。这仍然将导致获得好的性能。当然,LOAD DATA INFILE对装载数据仍然是更快的。

来源:赛迪网    
Oracle数据库服务启动时,这三个服务的启动或关闭还有先后的顺序。一般来讲,启动时必须先启动OracleOraHome90TNSListener再启动……
新版MySQL在背叛开源?MySQL成为Sun的摇钱树?LAMP会不会被SAMP所替代?LAMP是否会被取代?本文是从其新版发布中得出的几点启示。
我需要查询从现在算起五天前的日期。按照商业习惯,这五天应该不包含星期六和星期天。怎样查询不含周末的五天前的日期?
如今,开发人员不断地开发和部署使用LAMP(Linux?、Apache、MySQL 和 PHP/Perl)架构的应用程序。本文重点讨论为实现最高效率而对数据库层进行的调优。询进行优化。 09愢%_$ 炧%W?溹%$|x拟%笭倈鼱倈?疱%笭倈鼱倈h|?痍H?a溻%霆%N1n'N痍H(~&N伀%N4??綤?D??c%NpU% ?愱H,?ac%N,? ?=焸| uY焸|'ud?垙滉屷%fd%N{滉垙+?N栮橩'N愱H滉翎%P?ZL'N X?d?(?
MySQL性能调整之my.cnf文件的配置方法:[mysqld];datadir=/var/lib/mysql;socket=/var/lib/mysql/mysql.sock……
本篇文章主要介绍SQL Server数据存储的物理对象和原理,包括SQL Server 2005和2008里的物理数据存储、SQL Server 2008数据类型(即Datetime、字符串、自定义及等)、在SQL Server数据库中加强数据的完整性……
本文为SQL Server 2008初学者指南,主要介绍SQL Server2008 T-SQL支持的基本元素和基本操作。
本篇技术专题主要内容包括SQL Server整合、SQL Server数据库设计灾难、SQL Server数据库查询设计以及SQL Server数据库同步、复制、报告显示。
最新更新
专家答疑
技巧
Brian Peasland
我在使用这个工具的时候就出现了以上的错误。由于出现了这个错误,我就没有顺利地完成备份。你能告诉我是什么原因吗?
Rudy Limeback
我有一个有关用综合连接语句在不同范畴获取行数的问题……,该查询返回有行的三个stratum/treatment组合,但是没有返回没有行的一个组合。我尝试用对该值用……
Maria Anderson
我得到了一个错误信息,如“DIM-00019:创建服务错误。”我用你寄给我的解决方案解决这一问题,即:“手动创建和启动服务。”你能告诉我如何手动安装该服务吗?