[MySQL优化案例]系列 -- DISABLE/ENABLE KEYS的作用
作/译者:叶金荣
来源:http://imysql.cn
转载请注明作/译者和出处,并且不能用于商业用途,违者必究。
有一个表 tbl1 的结构如下:
CREATE TABLE `tbl1` ( `id` int(10) unsigned NOT NULL auto_increment, `name` char(20) NOT NULL default '', PRIMARY KEY (`id`), KEY `name` (`name`)) ENGINE=MyISAM DEFAULT CHARSET=utf8;该表里已经存在了200万条记录.
现在, 需要把 tbl1 中的所有记录全部导到另一个完全相同的表 tbl2 中去.
1. 如果采用以下传统的方式, 则执行时间为: 98.01s
mysql>INSERT INTO tbl2 SELECT * FROM tbl1;Query OK, 2000000 row affected (1 min 38.01 sec)Records: 2000000 Duplicates: 0 Warnings: 02. 如果是用以下SQL语句, 则执行时间为: 80.85s (36.30 + 44.55)
mysql>ALTER TABLE tbl2 DISABLE KEYS;Query OK, 0 rows affected (0.00 sec)mysql>INSERT INTO tbl2 SELECT * FROM tbl1;Query OK, 2000000 row affected (36.30 sec)Records: 2000000 Duplicates: 0 Warnings: 0mysql