Mycat只能做到分库不分表,和单库分表,不能做到一个库有0-4,另一个库有5-9
使用方式添加subTables="t_order$1-2,t_order3"。
目前分表1.6以后开始支持 并且dataNode在分表条件下只能配置一个,分表条件下不支持各种条件的join语句。
分库不分表,下面这样配,通过mycat 执行create table area_info,在dn1,dn2,dn3都会创建出来area_info
<?xml version="1.0"?> <!DOCTYPE mycat:schema SYSTEM "schema.dtd"> <mycat:schema xmlns:mycat="http://io.mycat/"> <!-- TESTDB1 是mycat的逻辑库名称,链接需要用的 --> <schema name="mycat_testdb" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"> <table name="area_info" dataNode="dn1,dn2,dn3" rule="role1"/> </schema> <!-- database 是MySQL数据库的库名 --> <dataNode name="dn1" dataHost="localhost" database="userdb_1" /> <dataNode name="dn2" dataHost="localhost" database="userdb_2" /> <dataNode name="dn3" dataHost="localhost" database="userdb_3" />
如果是单库分表就是这样的,通过subTables可以在一个库下多个分表
<mycat:schema xmlns:mycat="http://io.mycat/"> <!-- name: 逻辑数据库名 --> <schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"> <!-- name: 表名,分表主键,子表,数据节点,分表规则 --> <table name="ppartspaikong2" primaryKey="projectid" subTables="ppartspaikong_$2-4" dataNode="dn1" rule="jump-consistent-hash" /> </schema> <!-- database:物理数据库名 --> <dataNode name="dn1" dataHost="localhost1" database="test" />