MySQL 5.5 分區性能測試之索引使用情況

MySQL 5.5 分區性能測試之索引使用情況

1.創建一個測試表

  1. CREATE TABLE test (   
  2.   id VARCHAR(20) NOT NULL,  
  3.   name VARCHAR(20) NOT NULL,  
  4.   submit_time DATETIME NOT NULL,  
  5.   index time_index (submit_time),  
  6.   index id_index (id)  
  7. )ENGINE=MyISAM  
  8. PARTITION BY RANGE COLUMNS(submit_time)  
  9. (  
  10. PARTITION p1 VALUES LESS THAN ('2010-02-01'),  
  11. PARTITION p2 VALUES LESS THAN ('2010-03-01'),  
  12. PARTITION p3 VALUES LESS THAN ('2010-04-01'),  
  13. PARTITION p4 VALUES LESS THAN ('2010-05-01'),  
  14. PARTITION p5 VALUES LESS THAN ('2010-06-01'),  
  15. PARTITION p6 VALUES LESS THAN ('2010-07-01'),  
  16. PARTITION p7 VALUES LESS THAN ('2010-08-01'),  
  17. PARTITION p8 VALUES LESS THAN ('2010-09-01'),  
  18. PARTITION p9 VALUES LESS THAN ('2010-10-01'),  
  19. PARTITION p10 VALUES LESS THAN ('2010-11-01'),  
  20. PARTITION p11 VALUES LESS THAN ('2010-12-01')    
  21. );  

2.寫一個存儲過程,插入數據
  1. delimiter //    
  2. CREATE PROCEDURE mark_test()  
  3. begin   
  4.     declare v int default 0;   
  5.     while v < 8000   
  6.     do   
  7.        insert into test values (v,'testing partitions',adddate('2010-01-01', INTERVAL v hour));  
  8.        set v = v + 1;  
  9.     end while;  
  10. end //  
  11. delimiter ;  

3.實驗開始

 上面可以看到,這個是查某一個分區裏面的某一些內容,所以完全可以用到index.效果很好..

 

 上面可以看到,跨分區查詢,效果也非常不錯.

 

 上面可以到看,跨分區查詢是,如果某個分區沒有用到索引(p4就是全表掃描),整個也沒有用到index.但好的是,只掃描需要的分區
 
 
 上面可以看到,如果你不用分區的字段查詢,是很杯具的,因爲MySQL不知道你分區的index是分別存放到哪個分區上,所以要全index掃描, 
 
3.順便看看錶結構

a. 圖中test3 是innodb的存儲引擎, 
    test3.frm是表結構.
    test3.par是分區表的信息.
    數據和索引都是存放在表空間裏面在
b.圖中test是myisam的存儲引擎, 
   test.frm是表結構,
   test.par是分區表的信息.
   test#P#p10.MYD是數據文件之一,
   test#P#p10.MYI是索引文件之一
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章