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

[经验分享] mysql分区及分表(二)

[复制链接]

尚未签到

发表于 2018-9-28 06:18:27 | 显示全部楼层 |阅读模式
  mysql分区分表(二)
  测试未分区表和分区表性能
  重新创建新的测试数据库及未分区表back1
DSC0000.png

  创建分区表back2,按照年月区分
DSC0001.png

  maxvalue把对于2005的值全放在p11区里
  创建大点的数据(方便测试的时候区分明显分区和未分区的区别)
DSC0002.png

  rand()函数在0和1之间产生一个随机数,如果一个整数参数N指定,它被用作种子值。。每个种子产生的随机数序列是不同的
  执行存储过程load_part_tab向back2中插入数据
DSC0003.png

  向back1中插入数据
DSC0004.png

  测试未分区和分区的性能
DSC0005.png

  可以通过explain语句分析执行情况
DSC0006.png

  创建索引测试效果
DSC0007.png

  重启mysqld服务 可以看出时间相差不大,如果数据大会明显
DSC0008.png

  mysql分区类型
  1.range分区:基于属于一个给定连续区间的列值,把多行给分区,区间连续不能相互重叠;使用values less than定义
  创建新的表表名为benet1
DSC0009.png

  2.list分区:类似于range分区,区别在于基本列值是离散值集合
  list分区通过使用partition by list来实现
DSC00010.png

  这个可以在表中添加或删除指定地方的记录容易
  3.hash分区:允许dba通过对表的一个或多个列的hash key进行计算,最后通过hash码不同数值对应的数据区域进行分区
  使用hash算法分了四个区
DSC00011.png

  创建数据并且查看数据放在那个分区里
DSC00012.png

DSC00013.png

  查看分区的详细信息
  mysql> select * from information_schema.partitions where table_schema='test1' and table_name='benet3'\G;
  *************************** 1. row ***************************
  TABLE_CATALOG: def
  TABLE_SCHEMA: test1
  TABLE_NAME: benet3
  PARTITION_NAME: p0
  SUBPARTITION_NAME: NULL
  PARTITION_ORDINAL_POSITION: 1
  SUBPARTITION_ORDINAL_POSITION: NULL
  PARTITION_METHOD: HASH
  SUBPARTITION_METHOD: NULL
  PARTITION_EXPRESSION: year(b)
  SUBPARTITION_EXPRESSION: NULL
  PARTITION_DESCRIPTION: NULL
  TABLE_ROWS: 0
  AVG_ROW_LENGTH: 0
  DATA_LENGTH: 16384
  MAX_DATA_LENGTH: NULL
  INDEX_LENGTH: 0
  DATA_FREE: 0
  CREATE_TIME: 2017-06-22 18:01:56
  UPDATE_TIME: NULL
  CHECK_TIME: NULL
  CHECKSUM: NULL
  PARTITION_COMMENT:
  NODEGROUP: default
  TABLESPACE_NAME: NULL
  *************************** 2. row ***************************
  TABLE_CATALOG: def
  TABLE_SCHEMA: test1
  TABLE_NAME: benet3
  PARTITION_NAME: p1
  SUBPARTITION_NAME: NULL
  PARTITION_ORDINAL_POSITION: 2
  SUBPARTITION_ORDINAL_POSITION: NULL
  PARTITION_METHOD: HASH
  SUBPARTITION_METHOD: NULL
  PARTITION_EXPRESSION: year(b)
  SUBPARTITION_EXPRESSION: NULL
  PARTITION_DESCRIPTION: NULL
  TABLE_ROWS: 0
  AVG_ROW_LENGTH: 0
  DATA_LENGTH: 16384
  MAX_DATA_LENGTH: NULL
  INDEX_LENGTH: 0
  DATA_FREE: 0
  CREATE_TIME: 2017-06-22 18:01:56
  UPDATE_TIME: NULL
  CHECK_TIME: NULL
  CHECKSUM: NULL
  PARTITION_COMMENT:
  NODEGROUP: default
  TABLESPACE_NAME: NULL
  *************************** 3. row ***************************
  TABLE_CATALOG: def
  TABLE_SCHEMA: test1
  TABLE_NAME: benet3
  PARTITION_NAME: p2
  SUBPARTITION_NAME: NULL
  PARTITION_ORDINAL_POSITION: 3
  SUBPARTITION_ORDINAL_POSITION: NULL
  PARTITION_METHOD: HASH
  SUBPARTITION_METHOD: NULL
  PARTITION_EXPRESSION: year(b)
  SUBPARTITION_EXPRESSION: NULL
  PARTITION_DESCRIPTION: NULL
  TABLE_ROWS: 1
  AVG_ROW_LENGTH: 16384
  DATA_LENGTH: 16384
  MAX_DATA_LENGTH: NULL
  INDEX_LENGTH: 0
  DATA_FREE: 0
  CREATE_TIME: 2017-06-22 18:01:56
  UPDATE_TIME: 2017-06-22 18:02:57
  CHECK_TIME: NULL
  CHECKSUM: NULL
  PARTITION_COMMENT:
  NODEGROUP: default
  TABLESPACE_NAME: NULL
  *************************** 4. row ***************************
  TABLE_CATALOG: def
  TABLE_SCHEMA: test1
  TABLE_NAME: benet3
  PARTITION_NAME: p3
  SUBPARTITION_NAME: NULL
  PARTITION_ORDINAL_POSITION: 4
  SUBPARTITION_ORDINAL_POSITION: NULL
  PARTITION_METHOD: HASH
  SUBPARTITION_METHOD: NULL
  PARTITION_EXPRESSION: year(b)
  SUBPARTITION_EXPRESSION: NULL
  PARTITION_DESCRIPTION: NULL
  TABLE_ROWS: 0
  AVG_ROW_LENGTH: 0
  DATA_LENGTH: 16384
  MAX_DATA_LENGTH: NULL
  INDEX_LENGTH: 0
  DATA_FREE: 0
  CREATE_TIME: 2017-06-22 18:01:56
  UPDATE_TIME: 2017-06-22 18:02:57
  CHECK_TIME: NULL
  CHECKSUM: NULL
  PARTITION_COMMENT:
  NODEGROUP: default
  TABLESPACE_NAME: NULL
  4 rows in set (0.00 sec)
  ERROR:
  No query specified
  可以看到第三个分区p2中有一个数据记录
  4.key分区:key分区使用mysql数据库提供的函数进行分区,ndb cluster使用md5函数分区,对于其他存储引擎mysql内部的hash函数
  创建key分区、表、数据 查看数据会放到那个区里
DSC00014.png

  range、list、hash、key四种分区,分区条件必须整形,不是整形需要通过函数将其转换
  5.columns分区:从5.5开始支持columns分区,可以说是range和list的进化分区,可以直接使用非整形数据进行分区支持的数据:
  所有整形,如INT SMALLINT TINYINT BIGINT。FLOAT和DECIMAL则不支持。
  日期类型,如DATE和DATETIME。其余日期类型不支持。
  字符串类型,如CHAR、VARCHAR、BINARY和VARBINARY。BLOB和TEXT类型不支持。
  COLUMNS可以使用多个列进行分区。


运维网声明 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-602952-1-1.html 上篇帖子: mysql 5.7.21 二进制安装 下篇帖子: MySQL 5.5 日志管理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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