HIbernate 5:生成器类="序列"不工作

时间:2015-10-06 20:01:08

标签: java hibernate hibernate-5.x

我有以下映射:

    <id name="id" type="java.lang.Long" column="id">
        <generator class="sequence">
            <param name="sequence">tracksdata_seq</param>
        </generator>
    </id>

当我在Hibernate 4.2中使用它时,一切都很顺利。现在我正在迁移到Hibernate 5并面临以下问题:

2015-10-06 19:49:50 DEBUG SQL:92 - select nextval ('hibernate_sequence')
2015-10-06 19:49:50 DEBUG SqlExceptionHelper:122 - could not extract ResultSet [n/a]
org.postgresql.util.PSQLException: ERROR: relation "hibernate_sequence" does not exist

如何解决此问题?

P.S。 Hibernate 5.0.2.Final。

3 个答案:

答案 0 :(得分:10)

您有两种选择:

  1. 您将hibernate.id.new_generator_mappings配置属性设置为false并切换回旧的标识符生成器
  2. 您可以按如下方式更改映射:

    <generator class="sequence">
        <param name="sequence">MY_SEQUENCE</param>
    </generator>
    

    为:

    <generator class="org.hibernate.id.enhanced.SequenceStyleGenerator">
        <param name="optimizer">none</param>
        <param name="increment_size">1</param>
        <param name="sequence_name">MY_SEQUENCE</param>
    </generator>
    

答案 1 :(得分:1)

从Hibernate 4.3.10迁移到Hibernate 5.0.4时,我也遇到了这个问题。与maksim2020一样,我将<generator class="sequence">的实例替换为<generator class="identity">。但是,为了保留受影响的表的id序列,我还必须编写一个sql迁移脚本,该脚本将列的默认值设置为现有序列的下一个值。在PostgreSQL中,这可以完成如下:

ALTER TABLE ONLY affected_table ALTER COLUMN affected_id SET DEFAULT nextval('original_sequence'::regclass);

答案 2 :(得分:0)

"sequence_name"中使用"sequence"代替<param name="sequence">

这对我有用。