经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MyBatis » 查看文章
mybatis-plus动态表名的实现示例
来源:jb51  时间:2021/4/6 9:27:29  对本文有异议

背景

在分表的背景下,有时候查询数据的时候需要跨表查询,那此时就需要MP在解析的时候,能够很好的自适应表格名称

实现

MP中是通过PaginationInterceptor(分页插件)完成动态表名解析的,配置如下:

数据库中表

依赖

  1. <dependency>
  2. <groupId>com.baomidou</groupId>
  3. <artifactId>mybatis-plus-boot-starter</artifactId>
  4. <version>3.3.1.tmp</version>
  5. </dependency>

配置类

  1. package com.huanchuang.common.config;
  2. import com.baomidou.mybatisplus.extension.parsers.DynamicTableNameParser;
  3. import com.baomidou.mybatisplus.extension.parsers.ITableNameHandler;
  4. import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.optimize.JsqlParserCountOptimize;
  6. import org.mybatis.spring.annotation.MapperScan;
  7. import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
  8. import org.springframework.context.annotation.Bean;
  9. import org.springframework.context.annotation.Configuration;
  10. import java.util.Collections;
  11. import java.util.HashMap;
  12. /**
  13. * @Package: com.huanchuang.common.config
  14. * @Description: <mybatis-plush配置类>
  15. * @Author: MILLA
  16. * @CreateDate: 2020/09/04 14:42
  17. * @UpdateUser: MILLA
  18. * @UpdateDate: 2020/09/04 14:42
  19. * @UpdateRemark: <>
  20. * @Version: 1.0
  21. */
  22. @Configuration
  23. @MapperScan("com.huanchuang.ext.mapper**")
  24. @ConditionalOnProperty(prefix = "spring.config", name = "enableMybatisPlusDynamicTable", havingValue = "true")
  25. public class MybatisPlusDynamicTableConfig {
  26. private static final String DYNAMIC_TABLE_PRE = "common_user";
  27. /**
  28. * mybatis-plus分页插件
  29. */
  30. @Bean
  31. public PaginationInterceptor paginationInterceptor() {
  32. PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
  33. // 设置请求的页面大于最大页后操作, true调回到首页,false 继续请求 默认false
  34. paginationInterceptor.setOverflow(false);
  35. // 设置最大单页限制数量,默认 500 条,-1 不受限制
  36. paginationInterceptor.setLimit(500);
  37. // // 开启 count 的 join 优化,只针对部分 left join
  38. paginationInterceptor.setCountSqlParser(new JsqlParserCountOptimize(true));
  39. DynamicTableNameParser dynamicTableNameParser = new DynamicTableNameParser();
  40. dynamicTableNameParser.setTableNameHandlerMap(new HashMap<String, ITableNameHandler>(2) {{
  41. //动态表规则-生成自己需要的动态表名
  42. put(DYNAMIC_TABLE_PRE, (metaObject, sql, tableName) -> DynamicTableTreadLocal.INSTANCE.getTableName());
  43. }});
  44. paginationInterceptor.setSqlParserList(Collections.singletonList(dynamicTableNameParser));
  45. return paginationInterceptor;
  46. }
  47. }

动态表名存储类

  1. package com.huanchuang.common.config;
  2. /**
  3. * @Package: com.huanchuang.common.config
  4. * @Description: <动态表格存储类>
  5. * @Author: MILLA
  6. * @CreateDate: 2020/09/04 14:42
  7. * @UpdateUser: MILLA
  8. * @UpdateDate: 2020/09/04 14:42
  9. * @UpdateRemark: <>
  10. * @Version: 1.0
  11. */
  12. public enum DynamicTableTreadLocal {
  13. INSTANCE;
  14. private ThreadLocal<String> tableName = new ThreadLocal<>();
  15. public String getTableName() {
  16. return tableName.get();
  17. }
  18. public void setTableName(String tableName) {
  19. this.tableName.set(tableName);
  20. }
  21. public void remove() {
  22. tableName.remove();
  23. }
  24. }

使用

  1. private void select(int year) {
  2. DynamicTableTreadLocal.INSTANCE.setTableName("user_" + year);
  3. LambdaQueryWrapper<SparkDownSample> wrapper = Wrappers.lambdaQuery(User.class);
  4. List<User> userList = userMapper.list(wrapper )
  5. }
  1. @Data
  2. public class User {
  3. private Long id;
  4. private String userName;
  5. private String address;
  6. private char sex;
  7. private Byte age;
  8. }

原理

以mybatis的query方法作为入口通过动态代理执行到配置的分页插件通过分页插件进行sql解析根据分页插件中配置的tableNameHandler进行目标表格的替换最后形成一个可执行sql,执行查询

到此这篇关于mybatis-plus动态表名的实现示例的文章就介绍到这了,更多相关mybatis-plus 动态表名内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号