原创

MySQL多租户设计思路


前言

MySQL数据库的多租户实现方案主要有三种:

1、独立数据库模式

2、共享数据库独立schema模式

3、共享schema模式

从业界来讲,使用第三种共享schema模式的方式比较多,但是后期数据量大的话就涉及到分库分表。


实现方案

1、独立数据库模式,单体部署即可

2、共享数据库独立schema模式,可以采用mybatis插件的方式来实现多数据源,也可以采用Spring的AbstractRoutingDataSource来实现MySQL多数据源的切换,这种方式的有点是Spring框架自带,实现起来更为简单,而且自定义化的程度也较高。

3、共享数据库共享schema模式,在每个表上加上租户id字段,然后用Mybatis Plus的多租户拦截器来实现

public interface TenantLineHandler {

    /**
     * 获取租户 ID 值表达式,只支持单个 ID 值
     * <p>
     *
     * @return 租户 ID 值表达式
     */
    Expression getTenantId();

    /**
     * 获取租户字段名
     * <p>
     * 默认字段名叫: tenant_id
     *
     * @return 租户字段名
     */
    default String getTenantIdColumn() {
        return "tenant_id";
    }

    /**
     * 根据表名判断是否忽略拼接多租户条件
     * <p>
     * 默认都要进行解析并拼接多租户条件
     *
     * @param tableName 表名
     * @return 是否忽略, true:表示忽略,false:需要解析并拼接多租户条件
     */
    default boolean ignoreTable(String tableName) {
        return false;
    }
}
正文到此结束