循序渐进讲解MySQL数据库的性能调整
|
源代码网整理以下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语句那样夺的索引缓冲区清洗。如果你能用一个单个语句插入所有的行,锁定就不需要。锁定也将降低多连接测试的整体时间,但是对某些线程最大等待时间将上升(因为他们等待锁)。例如: 源代码网整理以下
源代码网供稿. |
