Spring Boot和Thymeleaf的单表继承视图和应用程序解决方案

问题描述

我决定使用单表继承,这将导致具有多个类,并且我无法通过应用程序视图部分中的父对象访问子字段 。到目前为止,我还没有找到如何在Thymeleaf中处理它的好方法。什么意思?
在拆分类以使用单表继承之前,我可以轻松地传递1个对象类,其中包含创建或显示对象所需的所有信息,但其中有太多字段为null。对于多个类,thymeleaf确实不允许您将对象转换为其他类型(据我了解,在应用程序的视图部分执行此操作不是一个好习惯)。那么,真正解决该问题的最佳方法是什么呢? 我可以提出以下想法:

  1. 创建一个DTO,其中包含所有类的字段并将对象转换为此类,这在create-view中非常有用(POST DTO,然后从中创建对象并添加数据库中)。但是,如果我使用这种方法显示信息,则意味着将每个对象都转换为DTO类,在我看来,这有点遗漏了单表继承的要点。我觉得这与根本不继承完全一样。
  2. 传递多个对象或父对象+一个不同的对象,这些对象将保留父类不保存的其余信息。这似乎也很奇怪。
  3. 在每个子类附加字段中向父类添加一个方法,并在子类中覆盖它们以返回实际值,而父类将返回null。不确定是否可以解决从视图创建对象的问题。

让我们假设此示例具有三个简单的类,其中Person是其父类,而Client和Employee是其子类。为了简单起见,我将跳过getter,setter和构造函数

拥有共享字段的人主类

@Entity
@Inheritance
@discriminatorColumn(name = "person_type",discriminatorType = discriminatorType.STRING)
public abstract class Person {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
int personId;
int age;
String name;
}  

客户类,使用其他字段 favouriteProduct

扩展人员
@Entity
@discriminatorValue(value= "CLIENT")
public class Client extends Person {

String favouriteProduct;
}

Employee 类,用于将人员扩展到其他字段,包括薪金和职位。

@Entity
@discriminatorValue(value= "EMPLOYEE")
public class Employee extends Person {

String position;
int salary;
}

鉴于这种简单的结构,我想通过POST请求通过一种形式创建Employee和Client对象,并在不同的视图中将它们一起显示,以及每个子类的唯一字段。问题是我需要将一个包含所有字段的对象传递给视图,以使其真正起作用,这又回到了我提出的问题和解决方案。有什么正确的方法或最佳实践来解决这个问题吗?我认为DTO应该从完整的对象缩减为字段较少的对象。

结论:如果答案不是那么简单,那么在这种情况下单表继承的真正用途是什么?为什么不回到1个表的实现不是一个好主意呢?我已经知道多态查询,这是一个不错的选择,但是到目前为止,我还不能真正解决上面说明的问题。预先感谢!

解决方法

我不了解Thymeleaf(很抱歉!),但是我确实了解一些面向对象的编程。撇开框架并从纯面向对象的角度进行讨论,父类对子代(继承者)一无所知。只有相反的情况才是正确的,那就是如果您使用适当的访问修饰符。如此说来,我相信除非有一些丑陋的框架黑魔法在幕后,否则我相信你不会做你想做的事。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...