java - 如何强制 Hibernate 保存无效值? (并不像听起来那么愚蠢)

标签 java sql hibernate jpa

这比标题看起来更复杂。问题是这样的:

我有一个 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:

http://docs.spring.io/spring/docs/2.5.6/api/org/springframework/web/portlet/mvc/AbstractWizardFormController.html

这里有一个教程:

http://www.mkyong.com/spring-mvc/spring-mvc-handling-multipage-forms-with-abstractwizardformcontroller/

关于java - 如何强制 Hibernate 保存无效值? (并不像听起来那么愚蠢),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21737876/

相关文章:

mysql - 具有日期范围的 SQL IN 运算符

java - 无法创建内部bean 'org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter....'

java - 如何坚持涉及@JoinFormula 的逆@OneToOne 映射?

具有缓存层的 Java 对象引用

java - 如何将 JButton 放置在小程序的底部?

javascript - OPTIONS 在 REST API 调用之前调用元数据

java - 比较两个 JComboBox 的值

java - Maven ojdbc jar依赖报错: package oracle. jdbc不存在

MySQL字符串选择命令

mysql - 连接被数据库丢弃