Mybatis拦截器实现公共字段填充

news/2025/1/8 14:27:25/文章来源:https://www.cnblogs.com/zzggqq/p/18656953

在使用MyBatis进行数据库操作时,通常需要对一些公共字段进行自动填充,例如创建时间、更新时间、创建人等。为了简化这些操作,可以使用MyBatis拦截器来实现公共字段的自动填充。本文将详细介绍如何实现这一功能。

实现步骤

1. 创建拦截器

首先,我们需要创建一个MyBatis拦截器。MyBatis提供了 Interceptor接口,我们可以通过实现该接口来定义自己的拦截逻辑。

import org.apache.ibatis.executor.Executor;
import org.apache.ibatis.mapping.MappedStatement;
import org.apache.ibatis.plugin.*;
import org.apache.ibatis.session.ResultHandler;
import org.apache.ibatis.session.RowBounds;import java.util.Date;
import java.util.Properties;@Intercepts({@Signature(type = Executor.class, method = "update", args = {MappedStatement.class, Object.class}),@Signature(type = Executor.class, method = "query", args = {MappedStatement.class, Object.class, RowBounds.class, ResultHandler.class})
})
public class CommonFieldInterceptor implements Interceptor {@Overridepublic Object intercept(Invocation invocation) throws Throwable {if (invocation.getArgs().length > 1) {Object parameter = invocation.getArgs()[1];if (parameter instanceof BaseEntity) {BaseEntity entity = (BaseEntity) parameter;if (isInsertOperation(invocation)) {entity.setCreateTime(new Date());entity.setUpdateTime(new Date());} else if (isUpdateOperation(invocation)) {entity.setUpdateTime(new Date());}}}return invocation.proceed();}private boolean isInsertOperation(Invocation invocation) {String methodName = ((MappedStatement) invocation.getArgs()[0]).getId();return methodName.contains("insert");}private boolean isUpdateOperation(Invocation invocation) {String methodName = ((MappedStatement) invocation.getArgs()[0]).getId();return methodName.contains("update");}@Overridepublic Object plugin(Object target) {return Plugin.wrap(target, this);}@Overridepublic void setProperties(Properties properties) {// 可选:设置属性}
}
​
 
 

2. 基础实体类

为了统一管理公共字段,我们需要创建一个基础实体类,所有需要自动填充公共字段的实体类都应继承该类。

import java.util.Date;public class BaseEntity {private Date createTime;private Date updateTime;// getters and setterspublic Date getCreateTime() {return createTime;}public void setCreateTime(Date createTime) {this.createTime = createTime;}public Date getUpdateTime() {return updateTime;}public void setUpdateTime(Date updateTime) {this.updateTime = updateTime;}
}
​
 
 

3. 配置拦截器

在MyBatis配置文件中注册拦截器。

<plugins><plugin interceptor="com.example.mybatis.interceptor.CommonFieldInterceptor"/>
</plugins>
​
 
 

4. 使用示例

创建一个继承 BaseEntity的实体类,并在Mapper中使用该实体类进行数据库操作。

public class User extends BaseEntity {private Long id;private String name;// getters and setterspublic Long getId() {return id;}public void setId(Long id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}
}
​
 
 
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Update;public interface UserMapper {@Insert("INSERT INTO user (name, create_time, update_time) VALUES (#{name}, #{createTime}, #{updateTime})")void insert(User user);@Update("UPDATE user SET name = #{name}, update_time = #{updateTime} WHERE id = #{id}")void update(User user);
}
​
 
 

关键点分析

拦截器

拦截器用于拦截MyBatis执行的SQL操作,通过 @Intercepts和 @Signature注解指定拦截的对象和方法。在 intercept方法中,我们通过判断操作类型(插入或更新)来填充相应的公共字段。

基础实体类

基础实体类 BaseEntity包含了需要自动填充的公共字段及其getter和setter方法。所有需要自动填充公共字段的实体类都应继承该类。

配置和使用

在MyBatis配置文件中注册拦截器,并在Mapper中使用继承自 BaseEntity的实体类进行数据库操作,确保公共字段能够自动填充。

分析说明表

步骤 描述
创建拦截器 实现 Interceptor接口,通过拦截MyBatis操作自动填充公共字段
基础实体类 定义包含公共字段的基础实体类,所有需要自动填充的实体类都继承该类
配置拦截器 在MyBatis配置文件中注册拦截器
使用示例 创建实体类和Mapper进行数据库操作,验证自动填充功能

思维导图

MyBatis拦截器实现公共字段填充
|
|-- 创建拦截器
|   |-- 实现Interceptor接口
|   |-- 判断操作类型(插入或更新)
|   |-- 填充公共字段
|
|-- 基础实体类
|   |-- 定义公共字段
|   |-- 继承BaseEntity
|
|-- 配置拦截器
|   |-- MyBatis配置文件中注册拦截器
|
|-- 使用示例
|   |-- 创建实体类
|   |-- 创建Mapper
|   |-- 执行数据库操作

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/865215.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

短剧拍摄中的高效协作:如何通过软件优化演员档期

一、短剧演员档期管理的挑战 短剧演员的档期管理比起传统电视剧演员更加紧张和复杂。短剧的拍摄周期较短,通常要求在较短的时间内完成多个剧本的拍摄。而演员往往同时参与多个项目的拍摄,这使得他们的工作时间安排变得异常繁琐。除了剧组安排的拍摄时间,演员还需安排彩排、试…

DC-4 靶场通关小记

暴力破解、反弹shell、nc传输文件、hydra爆破账号、邮件信息收集、权限水平提升、teehee追加写/etc/passwd提权地址 https://www.vulnhub.com/entry/dc-4,313/1. 环境配置 有其他兼容性问题参考 https://www.cnblogs.com/lrui1/p/18655388 2. 信息收集 fscan.exe -h 192.168.74…

如何解决超过1GB的文件压缩包上传失败的问题?

遇到超过1GB的文件压缩包上传失败的情况,通常可能是由于网络连接不稳定、FTP服务器配置限制或本地网络环境问题引起的。为了帮助您顺利解决问题,您可以按照以下步骤进行排查和处理:检查网络稳定性:首先,请确认您的网络连接是否稳定。由于上传大文件需要长时间保持稳定的网…

如何处理云服务器远程桌面访问问题

问题描述: 用户报告无法通过Web界面访问云服务器的远程桌面,怀疑可能是VNC固定端口受到攻击或端口未开放导致的问题。用户希望了解如何解决远程桌面访问失败的问题。 解决方案:确认远程桌面连接方式: 确保您使用的远程桌面连接工具和协议正确无误。常见的远程桌面工具包括:…

SSL证书部署后仍无法正常访问网站怎么办?

问题描述: 已经购买并上传了SSL证书到虚拟主机,但网站仍然无法通过HTTPS协议正常访问。如何排查和解决这一问题? 解决方案: 当您已经购买并上传了SSL证书到虚拟主机,但网站仍然无法通过HTTPS协议正常访问时,这可能是由于多个环节的问题所引起的。以下是详细的排查步骤和解…

如何解决远程登录问题

如果您遇到远程登录问题,可以按照以下步骤进行排查:检查SSH端口号:默认情况下,SSH端口号为22。如果您的服务器配置了非默认端口号(如22000),请确保使用正确的端口号进行连接。 您可以通过命令行工具(如 ssh)指定端口号进行连接,例如:ssh user@server_ip -p 22000。防…

如何实现网站代码自动恢复修改

在网站开发和维护过程中,有时会不小心修改了重要的代码文件,导致网站出现问题。如何实现网站代码的自动恢复,以避免数据丢失? 解决方案:使用版本控制系统:使用Git等版本控制系统来管理网站代码。版本控制系统可以帮助你跟踪每次修改的历史记录,方便回滚到之前的稳定版本…

如何高效地修改网站上的公司信息?

要高效地修改网站上的公司信息,请按照以下步骤操作:确定需要更新的内容:列出所有需要更新的公司信息项,如公司名称、地址、电话号码、邮箱地址等。 查找相关文件:定位到包含这些信息的文件或数据库表。通常情况下,这类信息会出现在首页、关于我们页面、联系我们页面等位置…

灵活定制,掌握网站模板全面修改的方法

网站模板的全面修改可以帮助您打造独特的品牌形象和用户体验。以下是具体操作指南:修改内容 方法页面布局 在后台的“模板”或“外观”选项中,选择要修改的模板文件(如index.htm),直接编辑HTML结构。也可以使用可视化编辑器调整布局。内容模块 进入“内容管理”模块,找到…

网站后台是否支持代码修改?

许多内容管理系统(CMS)提供了后台管理界面,用户可以通过这些界面进行内容更新和配置调整。但有时需要直接修改代码来实现特定功能或修复问题。 解决方案:了解权限:首先确认您是否有足够的权限访问和修改代码。某些CMS可能限制了普通用户的代码编辑权限。 使用开发者模式:…

MobaxTerm不能用ssh命令

问题1:MobaxTerm不能用ssh命令 1.1 症状 MobaxTerm版本:21.5用MobaXterm新建session去ssh正常。 用MobaXterm手动ssh失败,提示➤ ssh root@172.1.1.5 /etc/ssh_config line 8: Bad SSH2 cipher spec aes128-ctr,aes192-ctr,aes256-ctr,arcfour256,arcfour128,aes256-gcm@ope…

如何安全有效地修改网站首页图片以提升视觉效果

问题描述 如何在网站首页安全有效地修改图片,确保最终效果既美观又实用? 回答内容 修改网站首页图片是提升视觉效果和用户体验的重要步骤。以下是详细的指南,帮助您顺利完成这一任务:准备新的图片:确保新图片为常见的图像格式(如PNG、JPEG),并且尺寸适中,通常宽度为19…