gpt4 book ai didi

java - 更新依赖项后使用 TableGenerator 出现 ConstraintViolationException

转载 作者:行者123 更新时间:2023-12-02 02:22:33 26 4
gpt4 key购买 nike

将依赖项从 Spring 4.1.6.RELEASE 更新到 5.1.4.RELEASE 并将 Hibernate 4.3.9.Final 更新到 5.4.1.Final 后,我的一些测试用例开始失败,并在主键上出现 ConstraintViolationException。

由于历史原因,我们生成主数据如下:

@Id
@GeneratedValue(strategy = GenerationType.TABLE, generator = "NAME_HERE")
@TableGenerator(name = "NAME_HERE", table = "SEQUENCE_TABLE_NAME", pkColumnName = "Name", pkColumnValue = "ENTITY_NAME", valueColumnName = "VALUE_COLUMN_NAME", allocationSize = 100)

正常使用该应用程序时,这似乎不是问题,但是在运行测试时却出现了问题。

我注意到 ConstraintViolationException 仅发生在同一测试用例中插入多个值的表中。所以我认为这些行以某种方式分配了相同的主键。

在本地运行测试似乎不是问题,因此它也可能与测试在构建服务器上运行的方式有关。不过在升级依赖之前这不是问题。

我已经检查过序列值高于数据库中的最新值,但在升级依赖项之前这又不是问题。

我希望能唤起某人的内存:-)

最佳答案

我发现了这个: Hibernate, @SequenceGenerator and allocationSize

这让我找到了“hibernate.id.new_generator_mappings”

根据: https://docs.jboss.org/hibernate/orm/5.0/userguide/html_single/Hibernate_User_Guide.html#configurations

*指示新的 org.hibernate.id.IdentifierGenerator 是否用于 AUTO、TABLE 和 SEQUENCE 的设置。

现有应用程序可能需要禁用此功能(将其设置为 false),以实现从 3.x 和 4.x 到 5.x 的升级兼容性。*

将其设置为 false 解决了问题。

关于java - 更新依赖项后使用 TableGenerator 出现 ConstraintViolationException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57270067/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com