当前位置: 首页 > news >正文

通过枚举、AOP、注解、反射填充公共字段

在项目中,我们通常会实现员工管理和菜品管理等基础服务功能。这些服务在操作数据库时,往往需要记录一些通用字段,比如:  

创建人ID(`create_user_id`)  
修改人ID(`update_user_id`)  
创建时间(`create_time`)  
更新时间(`update_time`)  

当前实现的问题
1. 代码冗余
   - 每个新增、修改方法都需要手动设置这些字段,导致大量重复代码。  
   - 例如

        新增员工: 

employee.setUpdateTime(LocalDateTime.now());
employee.setCreateTime(LocalDateTime.now());
employee.setCreateUser(BaseContext.getCurrentId());
employee.setUpdateUser(BaseContext.getCurrentId());

        修改员工:

employee.setUpdateUser(BaseContext.getCurrentId());
employee.setUpdateTime(LocalDateTime.now());


   - 类似逻辑在**菜品管理、订单管理**等模块中反复出现。  

2. 维护成本高
   - 如果业务需求变更(如新增审计字段 `tenant_id`),需要在**所有相关方法**中修改,容易遗漏。  
   - 代码可读性降低,影响团队协作效率。  

---

优化方案
1. 使用 AOP(面向切面编程) 
在数据持久化前,自动注入 `create_time`、`update_time` 等字段。  
示例(Spring + AOP)
 

具体操作(此操作是针对项目中的,如是其他操作,需根据项目具体需要更改)

1自定义注解AutoFill,用于标识需要进行公共字段自动填充的方法

2自定义切面类AutoFillAspect,统一拦截加入了AutoFill注解的方法,通过反射为公共字段赋值

3在Mapper的方法上加入了AutoFill注解

1自定义注解AutoFill,用于标识需要进行公共字段自动填充的方法

2自定义切面类AutoFillAspect,统一拦截加入了AutoFill注解的方法

2.1通过反射为公共字段赋值

3在Mapper的方法上加入了AutoFill注解

优化后的优势  
✅ 减少重复代码:公共字段由框架自动管理。  
✅ 易于维护:修改基类或切面逻辑即可全局生效。  
✅ 业务聚焦:开发时只需关注核心逻辑,无需处理审计字段。


 适用场景:  
- 基于 Spring Boot
- 需要标准化审计字段的团队协作开发  

如果有更具体的需求(如多租户字段),可以进一步扩展基类或切面逻辑。

相关文章:

  • MySQL的进阶语法8(SQL优化——insert、主键、order by、group by、limit、count和update)
  • k8s pod security context 总结笔记
  • 自旋锁(C++实现)
  • js中一些便捷用法
  • 记一次表格数据排序优化(一)--排序30000条数据有多卡
  • MySQL基础 [一] - Ubuntu版本安装
  • Cribl 创建Dataset
  • NDK开发:JNI编程基础
  • 【C++】从零实现Json-Rpc框架(2)
  • 基于SpringBoot+Vue实现的二手交易市场平台功能一
  • 流影---开源网络流量分析平台(五)(成果展示)
  • 【Python学习】列表/元组等容器的常用内置函数详解
  • 【漫话机器学习系列】178.多元逻辑回归(Multinomial Logistic Regression)
  • CExercise_05_1函数_3交互式简易计算器
  • 量化交易提醒 - python发送邮件
  • OpenHarmony子系统开发 - DFX(三)
  • 华为TaurusDB、阿里PolarDB与腾讯TDSQL:信创需求下的国产数据库对比分析
  • 嵌入式硬件如何在PADS中将原理图转换为PCB详解
  • 【小沐学Web3D】three.js 加载三维模型(Angular)
  • MySQL 中 COUNT(*)、COUNT(1)、COUNT(字段) 有什么区别?