我有以下映射:
<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。
答案 0 :(得分:10)
您有两种选择:
hibernate.id.new_generator_mappings
配置属性设置为false并切换回旧的标识符生成器您可以按如下方式更改映射:
<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">
。
这对我有用。