<table name="news" primaryKey="id" type="global" dataNode="dataNode1" />
name表名称;
primaryKey为该表的主键
type=”global” 是啥?
有几个特性:
1、和具体物理表一一对应
2、多节点配置时出现 新增、修改操作时,则mycat会对所有节点(dataNode),发送该操作。保证所有节点里面的 全局表保持同步。
修改schema.xml
如下:
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://org.opencloudb/">
<schema name="mydbname" checkSQLschema="false" sqlMaxLimit="100">
<!-- type="global" 全局表 -->
<table name="news_class" primaryKey="class_id" autoIncrement="true" type="global" dataNode="dataNode1" />
</schema>
<!-- 节点配置 -->
<dataNode name="dataNode1" dataHost="dataHost1" database="test" />
<!-- balance="0" -->
<dataHost name="dataHost1" maxCon="1000" minCon="10" balance="0"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM1" url="10.211.55.13:3306" user="root" password="admin888"> </writeHost>
</dataHost>
</mycat:schema>
我这里只有一个节点(可以多个节点)
修改了配置文件 记得重启mycat服务哦
目前我们还没有配置文件中的news_class
数据表,我们需要新建这个表。
我这里使用终端进入mycat:
mysql -u mycat1 -p -h 127.0.0.1 -P 8066
#mycat1 这个是用户名是在server.xml中配置的 不要忘记哦
选择数据库:
mysql> use mydbname;
#mydbname schema.xml中配置的 你记得?
创建表:
CREATE TABLE `news_class` (
`class_id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT,
`class_name` char(255),
PRIMARY KEY (`class_id`)
);
做了这些到底在干嘛啊
想一想:刚才我们是连接mycat里创建的news_class
数据库,可是现在不仅mycat里有该表,我们的10.211.55.13
这个服务器也有这个表了(如果你配置的多节点,那么就都有)
到这里,差不多就知道 全局表 是个什么东西了。
在实战中
1、不经常产生修改的表,如配置表、类别表以及数据量不是很大的表 才会设置成全局表。
2、全局表修改时,会对所有节点进行同样的修改,保证同步
3、读取时,则随意从一个节点读取