唐山网站建设

设为主页 加入收藏 繁體中文

循序渐进讲授MySQL数据库的性能调剂

核心提示:循序渐进讲授MySQL数据库的性能调剂

MySQL的性能调剂:

INSERT查询的速度:

插进1个记录的时间由以下组成:

连接:(3)

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

分析查询:(2)

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

插进索引:(1 x 索引)

封闭:(1)

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

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

加快插进的1些方法:

假设你同时从同1客户插进很多行,使用多个值表的INSERT语句。这比使用分开INSERT语句快(在1些情况中几倍)。

假设你从不同客户插进很多行,你能通过使用INSERT DELAYED语句得到更高的速度。

留意,用MyISAM,假设在表中没有删除的行,能在SELECT:s正在运行的同时插进行。

当从1个文本文件装载1个表时,使用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;主要的速度差别是索引缓冲区仅被清洗到磁盘上1次,在所有INSERT语句完成后。1般有与有不同的INSERT语句那样夺的索引缓冲区清洗。假设你能用1个单个语句插进所有的行,锁定就不需要。锁定也将下降多连接测试的整体时间,但是对某些线程最大等待时间将上升(由于他们等待锁)。例如:


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次连续不断地插进或更新1行的东西加锁,你将取得更好的整体性能。假设你做很多1行的插进,你可以做1个LOCK TABLES,偶然随后做1个UNLOCK TABLES(大约每1000行)以答应另外的线程存取表。这依然将导致取得好的性能。固然,LOAD DATA INFILE对装载数据依然是更快的。

唐山网站建设www.fw8.net
TAG:性能,时间,语句,索引,速度
评论加载中...
内容:
评论者: 验证码: