mybatis实现公共字段填充
在表设计时,通常各个表有一些公共字段,比如主键、创建时间、最后修改时间等。这些字段如果都由开发人员去手动设置,一个是产生无用的代码,另外有可能规则不一致,造成错误。因此对于各个表的公用字段,一般会统一处理,MyBatis和Hibernate都有自身的拦截器,实现对应的接口,并配置即可。本文以MyBatis为例说明(mybatis-plus已经提供成熟代码)。假设各个表都有3个公共字段:id、gm.
·
@Intercepts({ @Signature(type = Executor.class, method = "update", args = { MappedStatement.class, Object.class }) })
public class CommonDbInterceptor implements Interceptor {
private Logger logger = LoggerFactory.getLogger(getClass());
private final static String FIELD_ID = "id";
private final static String FIELD_GMT_CREATE = "gmtCreate";
private final static String FIELD_GMT_MODIFIED = "gmtModified";
@SuppressWarnings({ "rawtypes" })
@Override
public Object intercept(Invocation invocation) throws Throwable {
try {
Object parameter = invocation.getArgs()[1];
Date now = new Date();
Class classParameter = (Class) parameter.getClass();
Field[] fields = classParameter.getDeclaredFields();
for (Field field : fields) {
field.setAccessible(true);
String fieldName = field.getName();
if (FIELD_ID.equalsIgnoreCase(fieldName)) {
Object value = field.get(parameter);
if (value == null) {
field.set(parameter, IdUtils.getLongId());
}
} else if (FIELD_GMT_CREATE.equalsIgnoreCase(fieldName)) {
Object value = field.get(parameter);
if (value == null) {
// gmtCreate只有插入才添加
MappedStatement mappedStatement = (MappedStatement) invocation.getArgs()[0];
SqlCommandType sqlCommandType = mappedStatement.getSqlCommandType();
if (SqlCommandType.INSERT.equals(sqlCommandType)) {
field.set(parameter, now);
}
}
} else if (FIELD_GMT_MODIFIED.equalsIgnoreCase(fieldName)) {
field.set(parameter, now);
}
}
} catch (Exception e) {
logger.error("通用设置值时出错", e);
}
return invocation.proceed();
}
@Override
public Object plugin(Object target) {
return Plugin.wrap(target, this);
}
@Override
public void setProperties(Properties properties) {
}
}

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐
所有评论(0)