Hibernate 期望 postgres 的序列而不是 table

Hibernate expects sequence instead of table for postgres

我的id代定义如下:

@Id
@GeneratedValue(generator = "pooled")
@GenericGenerator(name = "pooled", strategy = "org.hibernate.id.enhanced.TableGenerator", parameters = {
        @Parameter(name = "value_column_name", value = "sequence_next_hi_value"),
        @Parameter(name = "prefer_entity_table_as_segment_value", value = "true"),
        @Parameter(name = "optimizer", value = "pooled-lo"),
        @Parameter(name = "increment_size", value = "100")})
private Long id;

我正在使用 liquibase 生成 table 并让休眠验证模式,以便检测到忘记编辑变更日志。 hibernate_sequences 的 liquibase 定义如下:

<changeSet author="david (generated)" id="1477051164467-23">
    <createTable tableName="hibernate_sequences">
        <column name="sequence_name" type="varchar(255)">
            <constraints nullable="false"/>
        </column>
        <column name="sequence_next_hi_value" type="bigint"/>
    </createTable>
</changeSet>

这适用于我的本地 SQLServer Express 以及单元测试中使用的 h2 数据库。当我使用 postgres hibernate 在我们的开发服务器上部署应用程序时,需要一个数据库序列而不是使用序列 table: org.hibernate.tool.schema.spi.SchemaManagementException: Schema-validation: missing sequence [hibernate_sequence] 我认为使用 TableGenerator 策略不需要任何数据库上的序列。

使用 Spring 使用休眠 5.0 启动。11.Final

此时我们不知道生产中将使用哪些数据库,因此我需要一个 portable 解决方案。 (至少支持 Oracle、MsSQL、Postgres,MySql... 所以实际上几乎所有东西)

更新: 我已经安装了本地 postgres 并手动添加了序列以检查它是否使用。它确实被使用了(计数器是 3),但我不知道是哪个实体使用的。 我还为实体审计启用了 hibernate envers。 revinfo table 使用一个单独的序列,但是这个序列是由 liquibase 创建的。

原来,hibernate envers 默认实体使用 @GeneratedValue 因此需要序列

提前致谢。如果您需要更多信息,请随时询问。

请检查您的实体并检查它们是否都在使用 org.hibernate.id.enhanced.TableGenerator。这是唯一可能的原因 - 如果您看一下 https://github.com/hibernate/hibernate-orm/blob/5.0.11/hibernate-core/src/main/java/org/hibernate/id/enhanced/TableGenerator.java#L662,您会发现它不需要任何序列。