mybatis-plus 动态表名简易使用

news/2024/10/21 9:59:23/

场景:由于有些表是分表的,需要给表名添加后缀才能正确地访问表,如sys_user_2024_01

代码

依赖版本

        <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.3.4</version><scope>compile</scope></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-extension</artifactId><version>3.4.3.4</version><scope>compile</scope></dependency>

mybatisplus_21">mybatisplus配置类

java">/***  MybatisPlus 配置文件*/
@Configuration
@MapperScan({"com.xxx.dataana.mapper"})
public class MybatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();//动态表名实现DynamicTableNameInnerInterceptor dynamicTableNameInnerInterceptor = new DynamicTableNameInnerInterceptor();//可以传多个表名参数,指定哪些表使用TableNameSuffixHandler处理表名称dynamicTableNameInnerInterceptor.setTableNameHandler(new TableNameSuffixHandler("sys_user"));//以拦截器的方式处理表名称interceptor.addInnerInterceptor(dynamicTableNameInnerInterceptor);return interceptor;}

TableNameSuffixHandler

java">/*** mybatis-plus 成动态表名控制器*/
public class TableNameSuffixHandler implements TableNameHandler {/*** 用于记录哪些表可以使用该动态表名处理器(即哪些表需要分表)*/private final List<String> tableNames;/*** 构造函数,构造动态表名处理器的时候,传递tableNames参数* @param tableNames*/public TableNameSuffixHandler(String... tableNames) {this.tableNames = Arrays.asList(tableNames);}/*** 每个请求线程维护一个suffix数据,避免多线程数据冲突。所以使用ThreadLocal*/private static final ThreadLocal<String> TABLE_SUFFIX = new ThreadLocal<>();/*** 设置请求线程的表名后缀数据* @param tableNameSuffix*/public static void setSuffix(String tableNameSuffix) {TABLE_SUFFIX.set(tableNameSuffix);}/*** 删除请求线程的表名后缀数据* 注: 使用完必须释放*/public static void removeSuffix() {TABLE_SUFFIX.remove();}/*** 动态表名接口实现方法* @param sql* @param tableName* @return*/@Overridepublic String dynamicTableName(String sql, String tableName) {if (this.tableNames.contains(tableName)) {String suffix = TABLE_SUFFIX.get();if(suffix != null){//表名增加后缀return tableName + suffix;}}//表名原样返回return tableName;}
}

使用

java">    public ServiceResponse deleteRelaEventByRelaId(String anaVerId, String relaId) {LambdaUpdateWrapper<SysUser> luw = Wrappers.lambdaUpdate(SysUser.class).set(SysUser::getStatus, "0").set(SysUser::getUpdateTime, new Date()).eq(SysUser::getId, relaId);TableNameSuffixHandler.setSuffix("_2024_01");this.update(luw);TableNameSuffixHandler.removeSuffix();return ServiceResponse.createSuccess();}



参考:

  • Mybatis-Plus 之【动态表名】

http://www.ppmy.cn/news/1444263.html

相关文章

MySQL随便聊----之MySQL的调控按钮-启动选项和系统变量

-------MySQL是怎么运行的 基本介绍 如果你用过手机&#xff0c;你的手机上一定有一个设置的功能&#xff0c;你可以选择设置手机的来电铃声、设置音量大小、设置解锁密码等等。假如没有这些设置功能&#xff0c;我们的生活将置于尴尬的境地&#xff0c;比如在图书馆里无法把手…

编译Qt6.5.3LTS版本(Mac/Windows)的mysql驱动(附带编译后的全部文件)

文章目录 0 背景1 编译过程2 福利参考 0 背景 因为项目要用到对MYSQL数据库操作&#xff0c;所以需要连接到MYSQL数据库。但是连接需要MYSQL驱动&#xff0c;但是Qt本身不自带MYSQL驱动&#xff0c;需要自行编译。网上有很多qt之前版本的mysql驱动&#xff0c;但是没有找到qt6…

细说温度测量-热电偶1

细说温度测量——热电偶1 四种现代温标的转换公式热电偶测量热电偶电压参比端基准电路 四种现代温标的转换公式 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ K ˚C 273.15 ˚R ˚F 459.67 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ˚C 5/9 (…

利用Spring Boot后端与Vue前端技术构建现代化电商平台

作者介绍&#xff1a;✌️大厂全栈码农|毕设实战开发&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。 &#x1f345;获取源码联系方式请查看文末&#x1f345; 推荐订阅精彩专栏 &#x1f447;&#x1f3fb; 避免错过下次更新 Springboot项目精选实战案例 更多项目…

Centos编译安装python3.9

Centos编译安装python3.9 2024年4月24日, 当前Linux环境只能下载tar.gz包, 然后编译安装, 不能直接使用yum快速安装 准备相关依赖 yum -y install epel-release yum -y update 安装开发者工具 yum groupinstall "Development Tools" -y yum install openssl-de…

浏览器的同源策略与解决跨域

同源策略&#xff08;协议、域名、端口&#xff09; 同源策略&#xff08;Same-Origin Policy&#xff09;是一个在浏览器安全模型中被实施的重要安全机制。它是基于域名、协议和端口号的限制&#xff0c;用于防止不同源的网页间的恶意行为和信息泄露。 根据同源策略&#xf…

Swish和H-Swish激活函数:提升模型训练效率

文章目录 Swish激活函数H-Swish激活函数实现总结参考 在深度学习领域&#xff0c;激活函数是神经网络中的关键组成部分&#xff0c;它决定了网络的输出和性能。近年来&#xff0c;研究人员提出了许多新的激活函数&#xff0c;其中Swish激活函数因其独特的性能优势而备受关注。这…

分类预测 | Matlab实现CNN-GRU-SAM-Attention卷积门控循环单元融合空间注意力机制的数据分类预测

分类预测 | Matlab实现CNN-GRU-SAM-Attention卷积门控循环单元融合空间注意力机制的数据分类预测 目录 分类预测 | Matlab实现CNN-GRU-SAM-Attention卷积门控循环单元融合空间注意力机制的数据分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现CNN-GRU…