学习内容:
mybatis-plus 动态表名
学习产出:
第一步注册插件
@Configuration
public class MyBatisPlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
//prevent delete All
interceptor.addInnerInterceptor(new BlockAttackInnerInterceptor());//防止改、删全表
DynamicTableNameInnerInterceptor dynamicTableNameInnerInterceptor = new DynamicTableNameInnerInterceptor();
dynamicTableNameInnerInterceptor.setTableNameHandler(new MyTableNameHandler());//动态表名插件
interceptor.addInnerInterceptor(dynamicTableNameInnerInterceptor);
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));//分页插件
return interceptor;
}
}
第二步重写方法
public class MyTableNameHandler implements TableNameHandler {
//每个请求线程维护一个数据,避免多线程数据冲突。所以使用ThreadLocal
private static final ThreadLocal<String> SUFFIX = new ThreadLocal<>();
//设置请求线程的month数据
public static void setData(String suffix) {
SUFFIX .set(suffix);
}
@Override
public String dynamicTableName(String sql, String tableName) {
System.err.println("sql:" + sql );
String suffix = SUFFIX .get();
if(StringUtils.isNotBlank(suffix)){
SUFFIX .remove();
System.err.println("suffix:" + suffix );
System.err.println("动态查询表:" + tableName + suffix);
return tableName + suffix;
}
return tableName;
}
}
第三步在需要设置动态表名的地方调用方法
@Override
public Page<Student> selectByPage() {
Page<Student> page = PageController.getPageByRequest(request);
MyTableNameHandler.setData("_2021");//此处调用方法
return this.baseMapper.selectPage(page, null);
}
学习中遇到的问题:
分页插件导致动态表名失效,调整一下插件的添加顺序,优先添加动态表名插件,参考我代码添加顺序。