设为首页 收藏本站
查看: 808|回复: 0

[经验分享] MySQL分区摘要

[复制链接]

尚未签到

发表于 2018-10-4 14:49:30 | 显示全部楼层 |阅读模式
  MySQL支持的分区类型为水平分区,并不支持垂直分区。
  水平分区,以行为单位,划分到不同的物理文件中;垂直分区即针对列划分。
  MySQL的分区,除了InnoDB支持,MyISAM也支持,所以分区并不是引擎级别的事儿。
  分区并不一定会让访问变得更快,尤其是OLTP应用,OLAP应用使用分区的效果往往更好。
  MySQL支持的如下几种分区类型。


  • RANGE 行数据基于一个给定连续区间的列值划分。
  • LIST 和RANGE类似,只是LIST面向的不是连续区间值,而是离散的集合。
  • HASH 根据自定义的表达式返回值进行分区,不支持负数返回。
  • KEY 根据MySQL提供的hash函数进行分区
  不论按照哪种类型进行分区,如果当前表有主键或者唯一索引,分区列必须是唯一索引的组成部分。反过来,如果当前表没有定义主键也没有唯一索引,分区列可以是任何列。
  分区操作示例:
  

create table sales(id int, price decimal(9,2), season int, finyear datetime)  
partition by range(season) (
  
prtition s1 values less than (4),
  
partition s2 values less than (7),
  
partition s3 values less than (10),
  
partition s4 values less than (13));
  

  使用函数获取range值
  

create table sales(id int, price decimal(9,2), season int, finyear datetime)  
partition by range(year(finyear)) (
  
partition s1 values less than (2016),
  
partition s2 values less than (2017),
  
partition s3 values less than (2018),
  
partition s4 values less than (2020));
  

create table sales(id int, price decimal(9,2), season int, finyear datetime)  
partition by range(year(finyear)*100+ month(finyear)) (
  
partition s1 values less than (201804),
  
partition s2 values less than (201807),
  
partition s3 values less than (201810),
  
partition s4 values less than (201813));
  

  LIST分区示例
  

create table sales(id int, price decimal(9,2), season int, finyear datetime)  
partition by LIST(id) (
  
partition s1 values in (1,3,5,7,9),
  
partition s2 values in (2,4,6,8,10));
  

  HASH分区示例
  

create table sales(id int, price decimal(9,2), season int, finyear datetime) engine=innodb  
partition by hash(year(finyear));
  

  KEY分区示例
  

create table sales(id int, price decimal(9,2), season int, finyear datetime) engine=innodb  
partition by key(finyear);
  

分区后的数据存储结构及使用效果
  以RANGE分区为例
DSC0000.jpg

  插入数据
  

insert into sales select 1,10.05,1,'2018-01-01';  
insert into sales select 2,10.05,3,'2018-03-01';
  
insert into sales select 3,10.05,4,'2018-04-01';
  

  执行查询
  

explain partitions  
select * from sales where finyear < '2016-01-01';
  

DSC0001.jpg

  可以看到,查询优化器,直接跳过第四个分区,在前三个分区中查询,这就是要的效果。
  除了分区,还有分表、分库、分片操作,每一个都很重要,也都有各自的适用场景。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-611939-1-1.html 上篇帖子: MySQL使用group by 报this is incompatible with sql_mod 下篇帖子: MySql忘记密码解决办法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表