关于表变动而导致的实体变动问题

简介: 因为表变动而导致的实体变动问题,出现这种情况较多的是版本迭代的时候。 项目开发初期,表变动导致的代码改动量相对较小,改动后出现的问题也比较少。而在项目迭代的过程中,因为项目已经成型,大部分代码的逻辑和用法都已固定。

因为表变动而导致的实体变动问题,出现这种情况较多的是版本迭代的时候。

项目开发初期,表变动导致的代码改动量相对较小,改动后出现的问题也比较少。而在项目迭代的过程中,因为项目已经成型,大部分代码的逻辑和用法都已固定。此时表变动将有可能导致大量业务逻辑代码不可用。

这篇文章就说说因为表变动而需要修改的代码部分。

在此之前先说两个修改代码的小诀窍

修改代码的诀窍

诀窍一:

如果你用的开发工具是 IDEA 的话,你可以选中类名,然后按下 shift + F6 ,这时候会出现修改类名的对话框。在此处修改类名,将会把项目中有项目引用的地方一起修改。这个方法不仅方便,而且可以使你知道哪些地方的代码受到影响。

修改类名的对话框如下图:

_

诀窍二:

如果你用的开发工具是 IDEA 的话,当你删除类的时候会弹出如下对话框:

_1

选择“Safe delete(with usage search)”,点击“OK”,此时会出现如下对话框:

_2

点击“View Usages”,此时会出现如下对话框:

_3

你将看到因为删除类而产生的影响,即该类在哪些地方被引用了。

因表变动而导致的实体变动有以下四种修改方式:

说明:以下说明采用的示例均为原表是 User,现改为 BaseUser。

方式一:

先创建新表的实体类,然后删除旧表的实体类,即创建完 BaseUser 的实体之后,直接删除 User 实体。之后通过开发工具的报错信息,或者项目启动时候的报错,对项目中受到影响的代码进行修改。

开发工具的报错信息如下图:

_

项目启动时候的报错信息如下图:

_

优点:

能够快速定位受到影响的代码位置。

缺点

  1. 代码改动量大。
  2. 由于旧实体的删除而导致代码逻辑理解错误。
  3. 无法短时间内启动项目,必须把代码一次性改好。

方式二:

先创建新表的实体类,然后找出引用该实体相关代码将新旧实体进行替换,等全部替换完后再进行旧代码的删除。

优点:

  1. 可以短时间内对修改过的代码进行调试。
  2. 原业务逻辑都在,在修改代码时可以参考。

缺点:

在删除旧实体之前,容易遗漏受到影响的代码,从而导致项目开发进度受到影响(这个影响可大可小)。

方式三:

创建新表实体类,同时创建新表实体类的service、mapper等相关文件,之后将旧实体类的相关代码迁移到新表实体类的相关代码中。即同时 BaseUser 、BaseUserController、IBaseUserService、BaseUserServiceImpl、BaseUserMapper、BaseUserMapper.xml,之后将 User 、UserController、IUserService、UserServiceImpl、UserMapper、UserMapper.xml 的相关代码迁移到之前创建的代码中。

优点:

  1. 可以短时间内对修改过的代码进行调试。
  2. 原业务逻辑都在,在修改代码时可以参考。

缺点:

  1. 在删除旧实体之前,容易遗漏受到影响的代码,从而导致项目开发进度受到影响(这个影响可大可小)。
  2. 代码修改量大

方式四:

将旧实体类的表映射直接替换为新表的映射,即将原来的 @TableName("USER") 修改为 @TableName("BASE_USER"),同时将旧表实体的属性改为新表实体的属性。具体修改方式如下:

@EqualsAndHashCode(callSuper = true)
@TableName("BASE_USER")
@Data
public class User extends Model<User> {
    /**
     * 用户ID
     */
    @TableId(value = "ID",type = IdType.AUTO)
    private Integer id;
    /**
     * 用户名
     */
    @TableField("NAME")
    private String name;
    ......
}

优点:

  1. 在表字段修改不多的情况下,此种方法代码改动量最小。
  2. 可以短时间内对修改过的代码进行调试。

缺点:

由于旧实体的变动而导致代码逻辑理解错误。

综合以上四个方法,第四个方法相对较好

相关文章
|
关系型数据库 MySQL 数据库
mysql 8.0 递归(例子分享)(sample database classicmodels _No.4)
本文介绍了如何在MySQL8.0中使用递归查询处理部门表和员工表的树形结构数据,包括查看文档、准备数据、递归处理以及提取层级信息。作者通过示例展示了WITHRECURSIVE语句的应用及其在数仓中的结构表示。
223 2
|
1天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
242 116
|
16天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
10天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
637 221
|
存储 人工智能 监控
从代码生成到自主决策:打造一个Coding驱动的“自我编程”Agent
本文介绍了一种基于LLM的“自我编程”Agent系统,通过代码驱动实现复杂逻辑。该Agent以Python为执行引擎,结合Py4j实现Java与Python交互,支持多工具调用、记忆分层与上下文工程,具备感知、认知、表达、自我评估等能力模块,目标是打造可进化的“1.5线”智能助手。
866 61
|
8天前
|
人工智能 移动开发 自然语言处理
2025最新HTML静态网页制作工具推荐:10款免费在线生成器小白也能5分钟上手
晓猛团队精选2025年10款真正免费、无需编程的在线HTML建站工具,涵盖AI生成、拖拽编辑、设计稿转代码等多种类型,均支持浏览器直接使用、快速出图与文件导出,特别适合零基础用户快速搭建个人网站、落地页或企业官网。
1380 157
|
5天前
|
编解码 Linux 数据安全/隐私保护
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
265 139