MyCAT ELacrosse分片的求证

在此间,构造了两张表,熟谙Oracle的童鞋都晓得,dept(部门表)和emp(职员和工人表),个中dept中的deptno是emp表中dept_no的外键。

两表的建表语句如下:

create table dept(deptno int,dname varchar(10),datanode varchar(10));

create table emp(empno int,dept_no int,datanode varchar(10));

在意:在此地,最后一列都是datanode,通过插入database()函数能够很直观的收获插入的节点名,从而证实分片的功效。

各自测试以下二种处境:

  1. 父表依据主键ID分片,子表的分片字段与主表ID关联,配置为ECR-V分片
  2. 父表的分片字段为别的字段,子表的分片字段与主表ID关联,配置为E途乐分片

首先测试第2种境况,在此地,dept表作为父表,主键是deptno,empno为子表,关联字段为dept_no,分片字段为deptno。

schema.xml中的配置如下:

 <table name="dept" primaryKey="deptno" dataNode="dn1,dn2,dn3"
                rule="sharding-by-intfile">
                <childTable name="emp" primaryKey="empno" joinKey="dept_no"
                                parentKey="deptno">
                        </childTable>
  </table>

rule.xml中的配置如下:

 <tableRule name="sharding-by-intfile">
                <rule>
                        <columns>deptno</columns>
                        <algorithm>hash-int</algorithm>
                </rule>
        </tableRule>

修改很粗大略,便是将原先的id修改为deptno,代表分片的字段

 partition-hash-int.txt的值修改为:

10=0

20=1

 

证实如下:

插入父表的值,

datanode为db1,与partition-hash-int.txt中的配置相符

mysql> insert into dept(deptno,dname,datanode) values(10,'ACCOUNTING',database());
Query OK, 1 row affected (0.05 sec)

mysql> select * from dept;
+--------+------------+----------+
| deptno | dname      | datanode |
+--------+------------+----------+
|     10 | ACCOUNTING | db1      |
+--------+------------+----------+
1 row in set (0.12 sec)

日志输出新闻如下:

Oracle 1

接下去插入子表的值

mysql> insert into emp(empno,dept_no,datanode) values(7788,10,database());
Query OK, 1 row affected (0.01 sec)

日志输出信息如下:

Oracle 2

关键点在于“using parent partion rule
directly”。意思是一贯利用父的分片规则。假使表自身并从未点名外键约束。

则就是父并没有对号入座的主键值,子表还能够插入,只要分片规则中有着定义。

正如所示:

mysql> select * from emp;
+-------+---------+----------+
| empno | dept_no | datanode |
+-------+---------+----------+
|  7788 |      10 | db1      |
+-------+---------+----------+
1 row in set (0.52 sec)

mysql> select * from dept;
+--------+------------+----------+
| deptno | dname      | datanode |
+--------+------------+----------+
|     10 | ACCOUNTING | db1      |
+--------+------------+----------+
1 row in set (0.13 sec)

mysql> insert into emp(empno,dept_no,datanode) values(1234,20,database());
Query OK, 1 row affected (0.09 sec)

尽管dept中没有deptno为20的行。

但emp仍是能够插入dept_no为20的值

日志的输出新闻如下:

Oracle 3

之所以,对于第壹种情景,即父表根据主键分片,字表的分片字段与主表关联,结论便是,子表举行insert操作时,并不会检查父表中是或不是有有关的主键(对于子表的外键),而是平昔依据分片规则举办判定。

即使分片规则中平昔不定义,则会报如下错误:

mysql> insert into emp(empno,dept_no,datanode) values(1234,30,database());
ERROR 1064 (HY000): can't find datanode for sharding column:DEPTNO val:30

 

  1. 父表的分片字段为此外字段,子表的分片字段与主表ID关联,配置为E中华V分片

在此地,打算用dname作为分片字段,那样的话,只必要修改route.xml和partition-hash-int.txt了。

首先,修改rule.xml

<tableRule name="sharding-by-intfile">
                <rule>
                        <columns>dname</columns>
                        <algorithm>hash-int</algorithm>
                </rule>
        </tableRule>

<function name="hash-int"
                class="org.opencloudb.route.function.PartitionByFileMap">
                <property name="mapFile">partition-hash-int.txt</property>
                <property name="type">1</property>
        </function>

因dname是字符类型,故将type设置为1。

随着,修改算法配置文件的值

[root@mysql-server1 conf]# cat partition-hash-int.txt 
accounting,research=0
sales=1
operations=2

登录mycat管理端口,重新加载配置文件

[root@mysql-server1 conf]# mysql -h192.168.244.145 -utest -ptest
-P9066

mysql> reload @@config;
Query OK, 1 row affected (0.14 sec)
Reload config success

当今展开测试:

mysql> insert into dept(deptno,dname,datanode) values(10,'accounting',database());
Query OK, 1 row affected (0.14 sec)
mysql> insert into emp(empno,dept_no,datanode) values(1234,10,database());
Query OK, 1 row affected (0.29 sec)

日志的出口音信如下:

Oracle 4

插入第①个分区中的值

mysql> insert into dept(deptno,dname,datanode) values(20,'sales',database());
Query OK, 1 row affected (0.01 sec)

mysql> insert into emp(empno,dept_no,datanode) values(1234,20,database());
Query OK, 1 row affected (0.41 sec)

日志的出口消息如下:

Oracle 5

这一次是在四个分区查找子表的分区节点

Oracle,安顿第八个分区中的值

mysql>  insert into dept(deptno,dname,datanode) values(30,'operations',database());
Query OK, 1 row affected (0.00 sec)

mysql> insert into emp(empno,dept_no,datanode) values(4567,30,database());
Query OK, 1 row affected (0.62 sec)

日记的出口信息如下:

Oracle 6

在多少个分区中查找子表的分区节点

总括:在父表的分片字段为其余字段,子表的分片字段与主表ID关联那种景观下,子表的分区节点是逐一查找的,在该例中,依次从dn1,dn2和dn3中搜寻,假使dn第11中学存在,就直接插入到dn第11中学,反之,则三番五次查找dn2节点,假若仍不设有,则持续在dn3节点中查找。

相关文章