Mybatis-Plus多租户插件使用

核心插件: TenantLineInnerInterceptor

核心处理器:TenantLineHandler

public interface TenantLineHandler {

    /**
     * 获取租户 ID 值表达式,只支持单个 ID 值
     *
     * @return 租户 ID 值表达式
     */

    Expression getTenantId();

    /**
     * 获取租户字段名
     * <p>
     * <p>
     * <p>
     * 默认字段名叫: tenant_id
     *
     * @return 租户字段名
     */

    default String getTenantIdColumn() {

      return "tenant_id";

    }

    /**
     * 根据表名判断是否忽略拼接多租户条件
     * <p>
     * <p>
     * <p>
     * 默认都要进行解析并拼接多租户条件
     *
     * @param tableName 表名
     * @return 是否忽略, true:表示忽略,false:需要解析并拼接多租户条件
     */

    default boolean ignoreTable(String tableName) {

      return false;

    }

}

说明:

多租户 != 权限过滤,不要乱用,租户之间是完全隔离的!!!

启用多租户后所有执行的method的sql都会进行处理.

自写的sql请按规范书写(sql涉及到多个表的每个表都要给别名,特别是 inner join 的要写标准的 inner join)

/**
 * Mybatis模块自动装配类
 *
 */
@Configuration
public class MybatisPlusConfig {

    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        // 如果要使用分页插件,注意先 add TenantLineInnerInterceptor,再 add PaginationInnerInterceptor。
        // 分页插件PaginationInnerInterceptor必须要写在多租户插件后面)
        interceptor.addInnerInterceptor(new TenantLineInnerInterceptor(new TenantLineHandler() {
            // manager_id = 1088248166370832385
            // 获取租户 ID 值表达式,只支持单个 ID 值
            @Override
            public Expression getTenantId() {
                return new LongValue(1088248166370832385L);
            }

            @Override
            public String getTenantIdColumn() {
                return "manager_id";
            }

            // 这是 default 方法,默认返回 false 表示所有表都需要拼多租户条件,true表示不需要多租户条件
            @Override
            public boolean ignoreTable(String tableName) {
                // 不需要多租户条件的表可以继续在List中添加
                if (Arrays.asList("role", "user").contains(tableName)) {
                    return true;
                }
                return false;
            }
        }));

        // 分页插件
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }

    @Bean
    public ConfigurationCustomizer configurationCustomizer() {
        return configuration -> configuration.setUseDeprecatedExecutor(false);
    }
}

测试

@RunWith(SpringRunner.class)
@SpringBootTest
class TenantTest {

    @Resource
    UserMapper userMapper;

    @Test
    public void select() {
        // manager_id = 1088248166370832385
        List users = userMapper.selectList(null);
        users.forEach(System.out::println);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值