2012-05-13 39 views
3

我注意到在測試服務器上從表中刪除多行需要很多時間,例如,刪除100K行需要大約80-90秒。我在MySQL中使用innodb引擎。沒有DELETE觸發器。桌子現在有大約23M行。 這需要很長的查詢是這樣的:緩慢刪除mysql中的多條記錄

DELETE FROM contacts WHERE list_id = som_list_id 

指數增加。

EXPLAIN SELECT * 
FROM contacts 
WHERE list_id =118 

id select_type  table type possible_keys key  key_len  ref  rows Extra 
1 SIMPLE subscribers  ref  FK_list_id FK_list_id 4 const 1 

下面是分析結果:

SET PROFILING = 1; 
    DELETE FROM contacts WHERE list_id = 118; 
    SHOW PROFILE FOR QUERY 1; 


Status Duration CPU_user CPU_system Context_voluntary Context_involuntary  Block_ops_in Block_ops_out Messages_sent Messages_received Page_faults_major Page_faults_minor Swaps Source_function  Source_file  Source_line 
starting 0.000031 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL 
checking permissions 0.000004 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL check_access sql_parse.cc 4895 
Opening tables 0.000031 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL open_tables  sql_base.cc  4860 
System lock  0.000005 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_lock_tables lock.cc  299 
init 0.000079 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_delete sql_delete.cc 79 
updating 94.624119 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_delete sql_delete.cc 277 
end  0.000007 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_delete sql_delete.cc 356 
Waiting for query cache lock 0.000003 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL lock sql_cache.cc 749 
end  0.000006 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL 
query end 0.012509 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_execute_command sql_parse.cc 4584 
closing tables 0.000018 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_execute_command sql_parse.cc 4636 
freeing items 0.000038 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_parse  sql_parse.cc 5817 
logging slow query 0.000006 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL log_slow_statement sql_parse.cc 1581 
logging slow query 0.000000 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL log_slow_statement sql_parse.cc 1590 
cleaning up  0.000003 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL dispatch_command sql_parse.cc 1443 

我試圖複製聯繫人contact1不具有子表,其接觸有:分析的結果 是相似的:

Status Duration CPU_user CPU_system Context_voluntary Context_involuntary  Block_ops_in Block_ops_out Messages_sent Messages_received Page_faults_major Page_faults_minor Swaps Source_function  Source_file  Source_line 
starting 0.000028 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL 
checking permissions 0.000005 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL check_access sql_parse.cc 4895 
Opening tables 0.000035 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL open_tables  sql_base.cc  4860 
System lock  0.000014 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_lock_tables lock.cc  299 
init 0.000792 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_delete sql_delete.cc 79 
updating 72.805936 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_delete sql_delete.cc 277 
end  0.000006 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_delete sql_delete.cc 356 
Waiting for query cache lock 0.000002 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL lock sql_cache.cc 749 
end  0.000006 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL 
query end 0.013662 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_execute_command sql_parse.cc 4584 
closing tables 0.000017 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_execute_command sql_parse.cc 4636 
freeing items 0.000044 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL mysql_parse  sql_parse.cc 5817 
logging slow query 0.000003 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL log_slow_statement sql_parse.cc 1581 
logging slow query 0.000002 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL log_slow_statement sql_parse.cc 1590 
cleaning up  0.000003 NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL dispatch_command sql_parse.cc 1443 

它看起來像更新消耗大部分時間。

爲什麼刪除需要這麼長時間?由於服務器的I/O系統速度慢,是否需要這麼多時間? 謝謝。

+0

你的問題是什麼? – Mat

+2

您的DELETE與「EXPLAIN SELECT」和個人資料位於不同的表格中......我想這只是一個錯字? – eggyal

+0

這是相同的talble,我糾正。 – Oleg

回答

0

表MyISAM?如果是這樣嘗試

delete quick from contacts... 

其次

optimize table contacts 

使用快沒有數據庫合併過程中刪除索引。然後優化回收未使用的空間排列表。

+0

在我寫的問題中,我使用了innodb。 – Oleg