Chinaunix首页 | 论坛 | 博客
  • 博客访问: 6682999
  • 博文数量: 1005
  • 博客积分: 8199
  • 博客等级: 中将
  • 技术积分: 13071
  • 用 户 组: 普通用户
  • 注册时间: 2010-05-25 20:19
个人简介

脚踏实地、勇往直前!

文章分类

全部博文(1005)

文章存档

2020年(2)

2019年(93)

2018年(208)

2017年(81)

2016年(49)

2015年(50)

2014年(170)

2013年(52)

2012年(177)

2011年(93)

2010年(30)

分类: Mysql/postgreSQL

2017-08-10 10:49:03


sharding-by-month按照月份分库

1.rule.xml

点击(此处)折叠或打开

  1. <tableRule name="sharding-by-month">
  2.         <rule>
  3.                 <columns>createtime</columns>
  4.                 <algorithm>partbymonth</algorithm>
  5.         </rule>
  6. </tableRule>
  7. <function name="partbymonth"
  8.         class="io.mycat.route.function.PartitionByMonth">
  9.         <property name="dateFormat">yyyy-MM-dd HH:mm:ss</property>
  10.         <property name="sBeginDate">2015-01-01 00:00:00</property>
  11. </function>
dateFormat为日期格式,sBeginDate为开始日期

2.schema.xml
点击(此处)折叠或打开
  1. <?xml version="1.0"?>
  2. <!DOCTYPE mycat:schema SYSTEM "schema.dtd">
  3. <mycat:schema xmlns:mycat="">

  4.         <schema name="logdb" checkSQLschema="false" sqlMaxLimit="100">
  5.           <table name="tb_log_t" primaryKey="ID" autoIncrement="true" dataNode="dn1,dn2,dn3,dn4,dn5,dn6" rule="mod-long" />
  6.           <table name="tb_user_t" dataNode="dn1,dn2,dn3,dn4,dn5,dn6" rule="sharding-by-intfile-provcode" />
  7.           <table name="tb_user_detail_t" dataNode="dn1,dn2,dn3,dn4,dn5,dn6" rule="auto-sharding-long-userid" />
  8.           <table name="tb_user_murmur_t" dataNode="dn1,dn2,dn3,dn4,dn5,dn6" rule="sharding-by-murmur" />
  9.           <table name="tb_user_murmur_string_t" dataNode="dn1,dn2,dn3,dn4,dn5,dn6" rule="sharding-by-murmur-userid" />
  10.           <table name="tb_user_crc32slot_t" dataNode="dn1,dn2,dn3,dn4,dn5,dn6" rule="crc32slot" />
  11.           <table name="tb_user_partbymonth_t" dataNode="dn$1-13" rule="sharding-by-month" />
  12.         </schema>
  13.         <schema name="coss03" checkSQLschema="false" sqlMaxLimit="100" dataNode="dnoss03"/>
  14.         <dataNode name="dn1" dataHost="localhost1" database="log01" />
  15.         <dataNode name="dn2" dataHost="localhost1" database="log02" />
  16.         <dataNode name="dn3" dataHost="localhost1" database="log03" />
  17.         <dataNode name="dn4" dataHost="localhost1" database="log04" />
  18.         <dataNode name="dn5" dataHost="localhost1" database="log05" />
  19.         <dataNode name="dn6" dataHost="localhost1" database="log06" />
  20.         <dataNode name="dn7" dataHost="localhost1" database="log01" />
  21.         <dataNode name="dn8" dataHost="localhost1" database="log02" />
  22.         <dataNode name="dn9" dataHost="localhost1" database="log03" />
  23.         <dataNode name="dn10" dataHost="localhost1" database="log04" />
  24.         <dataNode name="dn11" dataHost="localhost1" database="log05" />
  25.         <dataNode name="dn12" dataHost="localhost1" database="log06" />
  26.         <dataNode name="dn13" dataHost="localhost1" database="log01" />
  27.         <dataNode name="dnoss03" dataHost="localhost1" database="oss03" />
  28.         <dataHost name="localhost1" maxCon="1000" minCon="10" balance="0"
  29.                           writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
  30.                 <heartbeat>select user()</heartbeat>
  31.                 <!-- can have multi write hosts -->
  32.                 <writeHost host="hostM1" url="192.168.56.141:3306" user="root"
  33.                                    password="mysql">
  34.                         <!-- can have multi read hosts -->
  35.                         <readHost host="hostS2" url="192.168.56.142:3306" user="root" password="mysql" />
  36.                 </writeHost>
  37.         </dataHost>
  38. </mycat:schema>
name="tb_user_partbymonth_t" 这里定义了"dn$1-13" 13个datanode,每个datanode写入不同的实际数据库(log01至log06),13个datanode,只能写入13个月份,月份从2015-01至2016-01,感觉这种分库方法不是很好,新增月份分库的时候还需要修改schema.xml文件,然后重启动mycat.

3.创建表
CREATE TABLE `tb_user_partbymonth_t` (
  `id` varchar(32) NOT NULL,
  `name` varchar(64) DEFAULT NULL,
  `createtime` datetime DEFAULT CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

写入数据(注意这里不能使用now函数)
insert into tb_user_partbymonth_t(id,name,createtime) values('a0001','name1','2015-01-01 10:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0002','name1','2015-02-02 10:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0003','name1','2015-03-01 00:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0004','name1','2015-04-01 00:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0005','name1','2015-05-01 10:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0006','name1','2015-06-02 10:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0007','name1','2015-07-01 00:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0008','name1','2015-08-01 00:00:00');

insert into tb_user_partbymonth_t(id,name,createtime) values('a0009','name1','2015-09-01 10:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0010','name1','2015-10-02 10:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0011','name1','2015-11-01 00:00:00');
insert into tb_user_partbymonth_t(id,name,createtime) values('a0012','name1','2015-12-01 00:00:00');

insert into tb_user_partbymonth_t(id,name,createtime) values('a0013','name1','2016-01-01 00:00:00');

-- The End --
阅读(7378) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~