gpt4 book ai didi

java - 如何通过遗留映射在 Hibernate 5 中指定基于序列的生成值

转载 作者:行者123 更新时间:2023-12-02 03:11:15 25 4
gpt4 key购买 nike

我有一个类似于 this question 的问题但以一种稍微不同的方式,一切就变得不同了。

我的问题是,我正在将项目组合从 Java 8/Hibernate 4.x 堆栈迁移到 Java 11/Hibernate 5.4 堆栈。

在第二种情况下,一旦应用程序尝试保存对象,我就会收到此错误:

org.postgresql.util.PSQLException: ERROR: relation "hibernate_sequence" does not exist

我上面提到的另一个问题的答案提供了一些见解,但我仍然不明白为什么会发生该错误:我们所有的实体都在使用每个自己的序列,并且该序列在相应的 hbm.xml 中明确指定。这是一个这样的映射文件:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping default-lazy="false">
<class name="…" table="data_receiving">
<id name="systemId" column="system_id">
<generator class="sequence">
<param name="sequence">system_id_seq</param>
</generator>
</id>
<property name="source" column="source" />

</class>
</hibernate-mapping>

看起来序列的规范被忽略了。我查找了一些旧版 Hibernate 与 XML 映射的文档,但找不到与 Hibernate 5 相关的任何内容,据报道 still supports such mappings .

解决方案可能是完全迁移到注释,但该组合包含十几个应用程序,其中有数十个表和总列数(在一个应用程序中)超过 1200 个。这项任务根本不切实际,更重要的是因为一些应用程序正在从头开始重写为微服务。

我的问题是我所使用的序列生成标识符的规范是否仍然受支持?

最佳答案

我必须深入研究 Hibernate 的源代码才能发现一个问题:参数 sequence 已重命名为 sequence_name

<param name="sequence">system_id_seq</param>

现在必须是

<param name="sequence_name">system_id_seq</param>

这使得有必要更新所有 hbm.xml 文件,我在 Eclipse 中使用查找和替换来完成此操作。

关于java - 如何通过遗留映射在 Hibernate 5 中指定基于序列的生成值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57527117/

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