zoukankan      html  css  js  c++  java
  • Mycat误区解释

    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" />
  • 相关阅读:
    mysql-索引与优化
    sql优化
    PHP高并发
    MySQL 数据类型
    ERROR 2013 (HY000): Lost connection to MySQL server
    建模各阶段以及相关UML构造笔记
    Code Complete 笔记—— 第二章 用隐喻来更充分理解软件开发
    Code Complete 笔记—— 第一章
    Laravel使用笔记 —— migration
    本地xdebug调试搭建 Laravel+homestead+phpstorm
  • 原文地址:https://www.cnblogs.com/juniorMa/p/14443805.html
Copyright © 2011-2022 走看看