MySQL5.5分区性能测试之索引使用情况
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL5.5分区性能测试之索引使用情况,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3024字,纯文字阅读大概需要5分钟。
内容图文
![MySQL5.5分区性能测试之索引使用情况](/upload/InfoBanner/zyjiaocheng/565/226a011514e34303a8b07458f2290c29.jpg)
转 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?
- 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')
- );
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?
- 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 ;
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是索引文件之一
内容总结
以上是互联网集市为您收集整理的MySQL5.5分区性能测试之索引使用情况全部内容,希望文章能够帮你解决MySQL5.5分区性能测试之索引使用情况所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。