登录
首页 >  数据库 >  MySQL

深入解析kingshard按时间分表的功能

来源:SegmentFault

时间:2023-01-14 21:08:39 308浏览 收藏

本篇文章向大家介绍《深入解析kingshard按时间分表的功能》,主要包括MySQL、go、mysql-proxy、kingshard,具有一定的参考价值,需要的朋友可以参考一下。

深入解析kingshard按时间分表的功能

文档中主要介绍了kingshard的Hash和Range方式的分表,最近又开发了按时间维度的分表方式。按时间维度分表的场景非常普遍,下面介绍一下kingshard的时间分表功能

1. 支持的时间类型

kingshard中的分表字段支持MySQL中三种类型的时间格式

  • date类型,格式:YYYY-MM-DD,例如:2016-03-04,注意:2016-3-04,2016-03-4,2016-3-4等格式kingshard都是不支持的。

  • datetime类型,格式:YYYY-MM-DD HH:MM:SS,例如:2016-03-04,注意:2016-3-04 13:23:43,2016-03-4  13:23:43,2016-3-4  13:23:43等格式kingshard都是不支持的,必须严格按照规定的格式,kingshard才支持。

  • timestamp类型,整数类型,例如:1457165568,对应的是:2016-3-5 16:12:48。

2. 支持的时间分表类型

kingshard支持MySQL中三种格式的时间类型

  • date类型,格式:YYYY-MM-DD,例如:2016-03-04,注意:2016-3-04,2016-03-4,2016-3-4等格式kingshard都是不支持的。

  • datetime,格式:YYYY-MM-DD HH:MM:SS,例如:2016-03-04,注意:2016-3-04 13:23:43,2016-03-4  13:23:43,2016-3-4  13:23:43等格式kingshard都是不支持的,必须严格按照规定的格式,kingshard才支持。

  • timestamp,整数类型。

3. 功能演示

kingshard的配置文件如下所示:

  • sharding key是ctime。

  • 按年的分表类型是:

  • sharding key是ctime。

  • 按年的分表类型是:

  • sharding key是ctime。

  • 按年的分表类型是:date_day。

  • test_shard_day_20151222, test_shard_day_20151223, test_shard_day_20151224两个子表落在node1上,test_shard_day_20160901,test_shard_day_20160902两个子表落在node2上。

  • 如果你一个node上只包含一张子表,你可以这样配置date_range[20150101,20160901-20161010]

  • 注意:子表的命名格式必须是:shard_table_YYYYMMDD,shard_table是分表名,后面接具体的年,月和日。

    功能演示参考按年分表的操作。

    kingshard开源地址:https://github.com/flike/king...

    公众号

    欢迎关注后端技术快讯公众号,有关kingshard的最新消息与后端架构设计类的文章,都会在这个公众号分享。

    图片描述

    今天带大家了解了MySQL、go、mysql-proxy、kingshard的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

    声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
    相关阅读
    更多>
    最新阅读
    更多>
    课程推荐
    更多>
    评论列表