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

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

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

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

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

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

修改代码的诀窍

诀窍一:

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

缺点:

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

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

相关文章
|
5月前
|
存储 SQL NoSQL
仓储设计实现问题之在仓储实体转移模式下处理聚合实体的删除如何解决
仓储设计实现问题之在仓储实体转移模式下处理聚合实体的删除如何解决
|
6月前
|
存储 关系型数据库 MySQL
如何获知表中数据被删除
如何获知表中数据被删除
57 4
|
6月前
领域驱动设计问题之将多个服务类都直接修改单据实体的状态如何解决
领域驱动设计问题之将多个服务类都直接修改单据实体的状态如何解决
|
SQL 安全 前端开发
案例07-在线人员列表逻辑混乱-ThreadLocal、继承、索引失效
案例07-在线人员列表逻辑混乱-ThreadLocal、继承、索引失效
|
数据库 缓存 索引
关系数据库设计中,用中间表好还是直接设定主外键关联好?
有人会对数据库有这样的疑问: 因为大多数的数据库教程上都是告诉你关系数据库如何去创建1:1、1:N和N:M的数据库关系,但我发现很多开源产品中,并没有直接使用关系数据库的关系查询、关系删除等功能,而是直接在代码中对多个表的查询结果进行组合。
2469 0
|
数据库 索引
存在逻辑删除的表字段上建立唯一索引的巧办法 (逻辑删除与唯一索引)
设计数据库唯一索引时,经常会碰到唯一删除的键值,导致很难处理,这里就简单介绍一种巧办法,帮你快速解决该问题
2009 0
存在逻辑删除的表字段上建立唯一索引的巧办法 (逻辑删除与唯一索引)
SAP 物料主数据分类视图维护了批次分类特性值以后,不允许去批次主数据里覆盖了?
SAP 物料主数据分类视图维护了批次分类特性值以后,不允许去批次主数据里覆盖了?
SAP 物料主数据分类视图维护了批次分类特性值以后,不允许去批次主数据里覆盖了?
|
Web App开发 API 数据库
零代码实现一对一表关系和无限主子表级联保存
本文主要介绍一对一关系和无限主子表在crudapi系统中的应用。一对一关系是指关系数据库中两个表之间的一种关系。关系数据库中第一个表中的单个行只可以与第二个表中的一个行相关,且第二个表中的一个行也只可以与第一个表中的一个行相关。
316 0
零代码实现一对一表关系和无限主子表级联保存
|
中间件 关系型数据库 MySQL
记一次保留订单历史记录的方案讨论
记一次保留订单历史记录的方案讨论
277 0