MyCat配置文件schema.xml讲解

1.MyCat配置

1.1 schema标签

如果checkSQLschema配置的为false,那么执行DB01.TB_ORDER时就会报错,必须用use切换逻辑库以后才能进行查询。

sqlMaxLimit如果未指定limit进行查询,列表查询模式默认为100,最多只查询100条。因为用mycat后默认数据量特别大,查询全表数据是十分耗费性能的。

要拆分的表我们都需要在table标签下进行定义,他变了标签有五个属性,name为表明,在整个逻辑库当中保证唯一就可以了。

dataNode表示这张逻辑表中的数据分布在哪几个数据节点当中。多个数据节点使用逗号分隔,这里面配置的dn1,dn2,dn3其实是一个引用需要和dataNode标签中的name对应。

rule指的是分片规则的名字,分片规则的名字是在rule.xml中定义的。

另外还可以在table标签里面定义primaryKey,逻辑表对应真是表的主键。

type是用来声明逻辑表的类型。

1.2 dataNode标签

dataNode标签中定义了MyCat中的数据节点,也就是我们常说的数据分片。一个dataNode标签就是一个独立的数据分片。

dataHost指的是节点主机,这个也需要在dataHost标签当中去定义,最后一个是database,它指定是当前这个数据节点关联的哪一个数据库。

1.3 dataHost标签

name指的是节点主机的唯一表示,供上层dataNode标签使用。

balance指的是负载均衡策略,取值有0,1,2,3

2.小结

schema标签配置的是逻辑库逻辑表,dataNode里面配置的是数据节点,dataHost配置的是节点主机以及关联的数据源的相关信息。

schema中指定逻辑库的库名,可以配置多个table指的是逻辑表,table里面的dataNode指的是这个数据表里面分为几片,存储到哪几个数据节点当中。dataNode关联下面dataNode标签里面的name属性。多个节点之间逗号分隔。

相关推荐
橘子师兄11 分钟前
分页功能组件开发
数据库·python·django
book01211 小时前
MySql数据库运维学习笔记
运维·数据库·mysql
纠结哥_Shrek1 小时前
Oracle和Mysql的区别
数据库·mysql·oracle
极客先躯1 小时前
说说高级java每日一道面试题-2025年2月13日-数据库篇-请说说 MySQL 数据库的锁 ?
java·数据库·mysql·数据库的锁·模式分·粒度分·属性分
做梦敲代码1 小时前
达梦统计信息
数据库·达梦数据库
jiugie2 小时前
MongoDB学习
数据库·python·mongodb
hzulwy2 小时前
MongoDB应用设计调优
数据库·mongodb
我爱松子鱼2 小时前
MySQL 单表访问方法详解
数据库·mysql
我们的五年2 小时前
MySQL存储引擎:选择与应用
数据库·mysql
计算机毕设指导62 小时前
基于Springboot学生宿舍水电信息管理系统【附源码】
java·spring boot·后端·mysql·spring·tomcat·maven