zoukankan      html  css  js  c++  java
  • mybatis-plus 多租户

    package com.ruoyi.framework.config;
    
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.transaction.annotation.EnableTransactionManagement;
    
    import com.baomidou.mybatisplus.annotation.DbType;
    import com.baomidou.mybatisplus.autoconfigure.ConfigurationCustomizer;
    import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
    import com.baomidou.mybatisplus.extension.plugins.handler.TenantLineHandler;
    import com.baomidou.mybatisplus.extension.plugins.inner.BlockAttackInnerInterceptor;
    import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;
    import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
    import com.baomidou.mybatisplus.extension.plugins.inner.TenantLineInnerInterceptor;
    import com.ruoyi.common.extension.MpSqlInjector;
    
    import lombok.AllArgsConstructor;
    import net.sf.jsqlparser.expression.Expression;
    import net.sf.jsqlparser.expression.LongValue;
    
    @AllArgsConstructor
    @EnableTransactionManagement(proxyTargetClass = true)
    @Configuration
    public class MybatisPlusConfig {
        @Bean
        public MybatisPlusInterceptor mybatisPlusInterceptor() {
            MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
            interceptor.addInnerInterceptor(new TenantLineInnerInterceptor(new TenantLineHandler() {
                // manager_id = 1088248166370832385
    
                // 获取租户 ID 值表达式,只支持单个 ID 值
                @Override
                public Expression getTenantId() {
    //                return new LongValue(1088248166370832385L);
                    return new LongValue(1L);
                }
    
                // 这是 default 方法,默认返回 false 表示所有表都需要拼多租户条件,
                // 这里设置 role表不需要该条件
                @Override
                public boolean ignoreTable(String tableName) {
    //                if ("role".equals(tableName)) {
    //                    return true;
    //                }
    //                return false;
                    if (tableName.substring(0, 2).equals("at"))
                        return false;
                    return true;
                }
    
                @Override
                public String getTenantIdColumn() {
                    return "tenantid";
                }
            }));
    
            // interceptor.addInnerInterceptor(tenantLineInnerInterceptor());
            // 如果用了分页插件注意先 add TenantLineInnerInterceptor 再 add
            // PaginationInnerInterceptor
            // 用了分页插件必须设置 MybatisConfiguration#useDeprecatedExecutor = false
            // 分页插件
            // interceptor.addInnerInterceptor(paginationInnerInterceptor());
    
            // 乐观锁插件
            interceptor.addInnerInterceptor(optimisticLockerInnerInterceptor());
            // 阻断插件
            interceptor.addInnerInterceptor(blockAttackInnerInterceptor());
            return interceptor;
        }
    
        @SuppressWarnings("deprecation")
        @Bean
        public ConfigurationCustomizer configurationCustomizer() {
            return configuration -> configuration.setUseDeprecatedExecutor(Boolean.FALSE);
        }
    
        @Bean
        public MpSqlInjector easySqlInjector() {
            return new MpSqlInjector();
        }
    
        /**
         * 分页插件,自动识别数据库类型 https://baomidou.com/guide/interceptor-pagination.html
         */
        public PaginationInnerInterceptor paginationInnerInterceptor() {
            PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
            // 设置数据库类型为mysql
            paginationInnerInterceptor.setDbType(DbType.MYSQL);
            // 设置最大单页限制数量,默认 500 条,-1 不受限制
            paginationInnerInterceptor.setMaxLimit(-1L);
            return paginationInnerInterceptor;
        }
    
        /**
         * 乐观锁插件 https://baomidou.com/guide/interceptor-optimistic-locker.html
         */
        public OptimisticLockerInnerInterceptor optimisticLockerInnerInterceptor() {
            return new OptimisticLockerInnerInterceptor();
        }
    
        /**
         * 如果是对全表的删除或更新操作,就会终止该操作
         * https://baomidou.com/guide/interceptor-block-attack.html
         */
        public BlockAttackInnerInterceptor blockAttackInnerInterceptor() {
            return new BlockAttackInnerInterceptor();
        }
        /**
         * sql性能规范插件(垃圾SQL拦截) 如有需要可以启用
         */
        // public IllegalSQLInnerInterceptor illegalSQLInnerInterceptor() {
        // return new IllegalSQLInnerInterceptor();
        // }
        /**
         * 自定义主键策略 https://baomidou.com/guide/id-generator.html
         */
        // @Bean
        // public IdentifierGenerator idGenerator() {
        // return new CustomIdGenerator();
        // }
        /**
         * 元对象字段填充控制器 https://baomidou.com/guide/auto-fill-metainfo.html
         */
        // @Bean
        // public MetaObjectHandler metaObjectHandler() {
        // return new MyMetaObjectHandler();
        // }
        /**
         * sql注入器配置 https://baomidou.com/guide/sql-injector.html
         */
        // @Bean
        // public ISqlInjector sqlInjector() {
        // return new DefaultSqlInjector();
        // }
        /**
         * TenantLineInnerInterceptor 多租户插件 本项目已经实现完整的多租户功能,但应用不广泛,基本框架中删除
         */
        // @Bean
        // public TenantLineInnerInterceptor tenantLineInnerInterceptor()
        // {
        // return new TenantLineInnerInterceptor(new TenantLineHandler()
        // {
        // /**
        // * 获取租户ID
        // * @return
        // */
        // @Override
        // public Expression getTenantId()
        // {
        // String tenant = TenantContextHolder.getTenantId();
        // if (tenant != null)
        // {
        // return new StringValue(TenantContextHolder.getTenantId());
        // }
        // return new StringValue("99999");
        // }
        //
        // /**
        // * 获取多租户的字段名
        // * @return String
        // */
        // @Override
        // public String getTenantIdColumn()
        // {
        // return tenantProperties.getColumn();
        // }
        //
        // /**
        // * 过滤不需要根据租户隔离的表
        // * 这是 default 方法,默认返回 false 表示所有表都需要拼多租户条件
        // * @param tableName 表名
        // */
        // @Override
        // public boolean ignoreTable(String tableName)
        // {
        // return tenantProperties.getIgnores().stream().anyMatch((t) ->
        // t.equalsIgnoreCase(tableName));
        // }
        // });
        // }
    }
    package com.ruoyi.framework.config;
    
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.transaction.annotation.EnableTransactionManagement;
    
    import com.baomidou.mybatisplus.annotation.DbType;
    import com.baomidou.mybatisplus.autoconfigure.ConfigurationCustomizer;
    import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
    import com.baomidou.mybatisplus.extension.plugins.handler.TenantLineHandler;
    import com.baomidou.mybatisplus.extension.plugins.inner.BlockAttackInnerInterceptor;
    import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;
    import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
    import com.baomidou.mybatisplus.extension.plugins.inner.TenantLineInnerInterceptor;
    import com.ruoyi.common.extension.MpSqlInjector;
    
    import lombok.AllArgsConstructor;
    import net.sf.jsqlparser.expression.Expression;
    import net.sf.jsqlparser.expression.LongValue;
    
    @AllArgsConstructor
    @EnableTransactionManagement(proxyTargetClass = true)
    @Configuration
    public class MybatisPlusConfig {
        @Bean
        public MybatisPlusInterceptor mybatisPlusInterceptor() {
            MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
            interceptor.addInnerInterceptor(new TenantLineInnerInterceptor(new TenantLineHandler() {
                // manager_id = 1088248166370832385
    
                // 获取租户 ID 值表达式,只支持单个 ID 值
                @Override
                public Expression getTenantId() {
    //                return new LongValue(1088248166370832385L);
                    return new LongValue(1L);
                }
    
                // 这是 default 方法,默认返回 false 表示所有表都需要拼多租户条件,
                // 这里设置 role表不需要该条件
                @Override
                public boolean ignoreTable(String tableName) {
    //                if ("role".equals(tableName)) {
    //                    return true;
    //                }
    //                return false;
                    if (tableName.substring(0, 2).equals("at"))
                        return false;
                    return true;
                }
    
                @Override
                public String getTenantIdColumn() {
                    return "tenantid";
                }
            }));
    
            // interceptor.addInnerInterceptor(tenantLineInnerInterceptor());
            // 如果用了分页插件注意先 add TenantLineInnerInterceptor 再 add
            // PaginationInnerInterceptor
            // 用了分页插件必须设置 MybatisConfiguration#useDeprecatedExecutor = false
            // 分页插件
            // interceptor.addInnerInterceptor(paginationInnerInterceptor());
    
            // 乐观锁插件
            interceptor.addInnerInterceptor(optimisticLockerInnerInterceptor());
            // 阻断插件
            interceptor.addInnerInterceptor(blockAttackInnerInterceptor());
            return interceptor;
        }
    
        @SuppressWarnings("deprecation")
        @Bean
        public ConfigurationCustomizer configurationCustomizer() {
            return configuration -> configuration.setUseDeprecatedExecutor(Boolean.FALSE);
        }
    
        @Bean
        public MpSqlInjector easySqlInjector() {
            return new MpSqlInjector();
        }
    
        /**
         * 分页插件,自动识别数据库类型 https://baomidou.com/guide/interceptor-pagination.html
         */
        public PaginationInnerInterceptor paginationInnerInterceptor() {
            PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
            // 设置数据库类型为mysql
            paginationInnerInterceptor.setDbType(DbType.MYSQL);
            // 设置最大单页限制数量,默认 500 条,-1 不受限制
            paginationInnerInterceptor.setMaxLimit(-1L);
            return paginationInnerInterceptor;
        }
    
        /**
         * 乐观锁插件 https://baomidou.com/guide/interceptor-optimistic-locker.html
         */
        public OptimisticLockerInnerInterceptor optimisticLockerInnerInterceptor() {
            return new OptimisticLockerInnerInterceptor();
        }
    
        /**
         * 如果是对全表的删除或更新操作,就会终止该操作
         * https://baomidou.com/guide/interceptor-block-attack.html
         */
        public BlockAttackInnerInterceptor blockAttackInnerInterceptor() {
            return new BlockAttackInnerInterceptor();
        }
        /**
         * sql性能规范插件(垃圾SQL拦截) 如有需要可以启用
         */
        // public IllegalSQLInnerInterceptor illegalSQLInnerInterceptor() {
        // return new IllegalSQLInnerInterceptor();
        // }
        /**
         * 自定义主键策略 https://baomidou.com/guide/id-generator.html
         */
        // @Bean
        // public IdentifierGenerator idGenerator() {
        // return new CustomIdGenerator();
        // }
        /**
         * 元对象字段填充控制器 https://baomidou.com/guide/auto-fill-metainfo.html
         */
        // @Bean
        // public MetaObjectHandler metaObjectHandler() {
        // return new MyMetaObjectHandler();
        // }
        /**
         * sql注入器配置 https://baomidou.com/guide/sql-injector.html
         */
        // @Bean
        // public ISqlInjector sqlInjector() {
        // return new DefaultSqlInjector();
        // }
        /**
         * TenantLineInnerInterceptor 多租户插件 本项目已经实现完整的多租户功能,但应用不广泛,基本框架中删除
         */
        // @Bean
        // public TenantLineInnerInterceptor tenantLineInnerInterceptor()
        // {
        // return new TenantLineInnerInterceptor(new TenantLineHandler()
        // {
        // /**
        // * 获取租户ID
        // * @return
        // */
        // @Override
        // public Expression getTenantId()
        // {
        // String tenant = TenantContextHolder.getTenantId();
        // if (tenant != null)
        // {
        // return new StringValue(TenantContextHolder.getTenantId());
        // }
        // return new StringValue("99999");
        // }
        //
        // /**
        // * 获取多租户的字段名
        // * @return String
        // */
        // @Override
        // public String getTenantIdColumn()
        // {
        // return tenantProperties.getColumn();
        // }
        //
        // /**
        // * 过滤不需要根据租户隔离的表
        // * 这是 default 方法,默认返回 false 表示所有表都需要拼多租户条件
        // * @param tableName 表名
        // */
        // @Override
        // public boolean ignoreTable(String tableName)
        // {
        // return tenantProperties.getIgnores().stream().anyMatch((t) ->
        // t.equalsIgnoreCase(tableName));
        // }
        // });
        // }
    }

    有追求,才有动力!

    向每一个软件工程师致敬!

    by wujf

    mail:921252375@qq.com

  • 相关阅读:
    Tomcat全攻略
    JAVA必备——13个核心规范
    利用Node.js实现模拟Session验证的登陆
    Android中关于JNI 的学习(六)JNI中注冊方法的实现
    pomelo源代码分析(一)
    怎样解决栈溢出
    String,StringBuffer与StringBuilder的差别??
    ERWin 7.1 和7.2 的官方FTP下载地址
    C/C++中各种类型int、long、double、char表示范围(最大最小值)
    下拉刷新,上拉装载许多其他ListView
  • 原文地址:https://www.cnblogs.com/wujf/p/15335160.html
Copyright © 2011-2022 走看看