这比标题看起来更复杂。问题是这样的:
我有一个 Spring Web Flow 应用程序,它是一系列表单,用户按特定顺序在其中移动。两个表单,我们称之为“表单 2”和“表单 3”,填充同一个数据库表的不同字段,我们称之为“公司”。麻烦的是,Company 表都是不可为空的字段。因此,当用户填写“表单 2”字段并尝试保存时,“表单 3”字段必须填充一些内容。例如,我必须在“员工数量”字段中保存外键值。
然后,在“Form 3”中,我必须读回这些字段并忽略刚刚写入的值,并向用户呈现一个空白表单。我想在 FK 字段中保存一个“哨兵”值,并在重新读取时检测它。然而,我正在使用 Hibernate,并且无法确定正确的语法来使 Hibernate 在这种情况下保存本质上“无效”的外键。
我需要标记的表字段是这样的:
NUMBER_OF_EMPLOYEES CHAR(1) DEFAULT ' ' NOT NULL
该列是NOT NULL
,所以我不能只在其中放入NULL
。我需要放入垃圾数据的Hibernate/JPA关系是这样的:
@ManyToOne(optional=true)
@JoinColumn(name = "NUMBER_OF_EMPLOYEES", nullable = true)
private NumberOfEmployees numberOfEmployees;
如果有效键是“A”、“B”和“C”,我想在此处输入“X”。这可能吗?如果可能的话,如何实现?
最佳答案
答案:您不会,至少在不修改数据库中的基础表的情况下,因为即使 Hibernate 不这样做,您的数据库服务器也会强制执行非空属性。如果无法使用以下信息,您最好的选择是在 session 上传递一个对象,该对象逐渐被数据填满。
但是,既然您提到您正在使用 Spring,也许您可以实现 AbstractWizardFormController
。这允许您随时填充数据,一旦用户完成最后一页,您就可以将所有数据提交到数据库。
请参阅此处的 javadoc:
这里有一个教程:
关于java - 如何强制 Hibernate 保存无效值? (并不像听起来那么愚蠢),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21737876/