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

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

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

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

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

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

修改代码的诀窍

诀窍一:

如果你用的开发工具是 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. 可以短时间内对修改过的代码进行调试。

缺点:

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

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

相关文章
|
弹性计算 Java PHP
新手用户注册阿里云账号、实名认证、购买云服务器图文教程参考
对于初次购买阿里云产品的用户来说,第一步要做的是注册账号并完成实名认证,然后才是购买阿里云服务器或者其他云产品,本文为大家以图文形式展示一下新手用户从注册阿里云账号、实名认证到购买云服务器完整详细教程,以供参考。
新手用户注册阿里云账号、实名认证、购买云服务器图文教程参考
|
关系型数据库 MySQL 数据库
mysql 8.0 递归(例子分享)(sample database classicmodels _No.4)
本文介绍了如何在MySQL8.0中使用递归查询处理部门表和员工表的树形结构数据,包括查看文档、准备数据、递归处理以及提取层级信息。作者通过示例展示了WITHRECURSIVE语句的应用及其在数仓中的结构表示。
193 2
|
JSON 数据处理 Go
一文教会你如何使用 iLogtail SPL 处理日志
iLogtail 作为日志、时序数据采集器,在 2.0 版本中,全面支持了 SPL 。本文对处理插件进行了梳理,介绍了如何编写 SPL 语句,从插件处理模式迁移到 2.0 版本的 SPL 处理模式,帮助用户实现更加灵活的端上数据处理。
802 132
|
12月前
|
Linux
Linux - 如何编译源码安装软件
源码编译安装通常包括三个步骤:1) `./configure` 检测平台特征和依赖项,生成 Makefile;2) `make` 编译源码,生成可执行文件;3) `make install` 将可执行文件安装到指定目录并配置环境变量。
331 0
|
存储 缓存 安全
一起学点ARM的微架构?
一起学点ARM的微架构?
603 0
|
SQL 存储 算法
PostgreSQL并行HashJoin解读
PostgreSQL并行HashJoin解读
PostgreSQL并行HashJoin解读
|
DataWorks 大数据 调度
【全新系列】DataWorks百问百答
通过本系列,您可以了解各种DataWorks产品使用的最佳实践/黑科技/产品必知必会/常见使用问题等等
29048 1
Uma
|
Oracle 关系型数据库 分布式数据库
DTCC 2019 | 深度解码阿里数据库实现 数据库内核——基于HLC的分布式事务实现深度剖析
摘要:分布式事务是分布式数据库最难攻克的技术之一,分布式事务为分布式数据库提供一致性数据访问的支持,保证全局读写原子性和隔离性,提供一体化分布式数据库的用户体验。本文主要分享分布式数据库中的时钟解决方案及分布式事务管理技术方案。
Uma
8386 0
下一篇
开通oss服务