最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL5.5分区性能测试之索引使用情况

来源:懂视网 责编:小采 时间:2020-11-09 15:35:40
文档

MySQL5.5分区性能测试之索引使用情况

MySQL5.5分区性能测试之索引使用情况:转 http://blog.csdn.net/m582445672/article/details/7800694 1.创建一个测试表 [sql] view plaincopyprint CREATE TABLE test( id VARCHAR (20) NOT NULL , name VARCHAR (20) NOT NULL , submit
推荐度:
导读MySQL5.5分区性能测试之索引使用情况:转 http://blog.csdn.net/m582445672/article/details/7800694 1.创建一个测试表 [sql] view plaincopyprint CREATE TABLE test( id VARCHAR (20) NOT NULL , name VARCHAR (20) NOT NULL , submit

转 http://blog.csdn.net/m582445672/article/details/7800694 1.创建一个测试表 [sql] view plaincopyprint? CREATE TABLE test( id VARCHAR (20) NOT NULL , name VARCHAR (20) NOT NULL , submit_timeDATETIME NOT NULL , index time_index(submit_time),

转 http://blog.csdn.net/m582445672/article/details/7800694

1.创建一个测试表

[sql] view plaincopyprint?

  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. );

CREATE TABLE test ( 
 id VARCHAR(20) NOT NULL,
 name VARCHAR(20) NOT NULL,
 submit_time DATETIME NOT NULL,
 index time_index (submit_time),
 index id_index (id)
)ENGINE=MyISAM
PARTITION BY RANGE COLUMNS(submit_time)
(
PARTITION p1 VALUES LESS THAN ('2010-02-01'),
PARTITION p2 VALUES LESS THAN ('2010-03-01'),
PARTITION p3 VALUES LESS THAN ('2010-04-01'),
PARTITION p4 VALUES LESS THAN ('2010-05-01'),
PARTITION p5 VALUES LESS THAN ('2010-06-01'),
PARTITION p6 VALUES LESS THAN ('2010-07-01'),
PARTITION p7 VALUES LESS THAN ('2010-08-01'),
PARTITION p8 VALUES LESS THAN ('2010-09-01'),
PARTITION p9 VALUES LESS THAN ('2010-10-01'),
PARTITION p10 VALUES LESS THAN ('2010-11-01'),
PARTITION p11 VALUES LESS THAN ('2010-12-01') 
);


2.写一个存储过程,插入数据

[sql] view plaincopyprint?

  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 ;

delimiter // 
CREATE PROCEDURE mark_test()
begin 
 declare v int default 0; 
 while v < 8000 
 do 
 insert into test values (v,'testing partitions',adddate('2010-01-01', INTERVAL v hour));
 set v = v + 1;
 end while;
end //
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是索引文件之一

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

MySQL5.5分区性能测试之索引使用情况

MySQL5.5分区性能测试之索引使用情况:转 http://blog.csdn.net/m582445672/article/details/7800694 1.创建一个测试表 [sql] view plaincopyprint CREATE TABLE test( id VARCHAR (20) NOT NULL , name VARCHAR (20) NOT NULL , submit
推荐度:
标签: 使用 测试 情况
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top