当从 Hibernate 5.2 迁移到 5.3 时,Hibernate 会尝试使用一个奇怪的序列



从休眠5.2.17升级到5.3.6后,我收到此错误:

Caused by: org.h2.jdbc.JdbcSQLException: Schéma "ENHANCED" non trouvé
Schema "ENHANCED" not found; SQL statement:
call next value for enhanced.SequenceStyleGenerator [90079-197]
at org.h2.engine.SessionRemote.done(SessionRemote.java:623) ~[h2-1.4.197.jar:1.4.197]
at org.h2.command.CommandRemote.prepare(CommandRemote.java:85) ~[h2-1.4.197.jar:1.4.197]
at org.h2.command.CommandRemote.<init>(CommandRemote.java:51) ~[h2-1.4.197.jar:1.4.197]
at org.h2.engine.SessionRemote.prepareCommand(SessionRemote.java:493) ~[h2-1.4.197.jar:1.4.197]
at org.h2.jdbc.JdbcConnection.prepareCommand(JdbcConnection.java:1247) ~[h2-1.4.197.jar:1.4.197]
at org.h2.jdbc.JdbcPreparedStatement.<init>(JdbcPreparedStatement.java:76) ~[h2-1.4.197.jar:1.4.197]
at org.h2.jdbc.JdbcConnection.prepareStatement(JdbcConnection.java:304) ~[h2-1.4.197.jar:1.4.197]
at com.mchange.v2.c3p0.impl.NewProxyConnection.prepareStatement(NewProxyConnection.java:567) ~[c3p0-0.9.5.2.jar:0.9.5.2]
at org.hibernate.engine.jdbc.internal.StatementPreparerImpl$1.doPrepare(StatementPreparerImpl.java:87) ~[hibernate-core-5.3.6.Final.jar:5.3.6.Final]
at org.hibernate.engine.jdbc.internal.StatementPreparerImpl$StatementPreparationTemplate.prepareStatement(StatementPreparerImpl.java:172) ~[hibernate-core-5.3.6.Final.jar:5.3.6.Final]

id 字段以这种方式注释:

@Id
@GeneratedValue(generator = "enhanced.SequenceStyleGenerator")
@GenericGenerator(
name = "enhanced.SequenceStyleGenerator", 
parameters = {
// this value needs to be used when creating the sequence in "increment-by" clause.
@Parameter(name = "increment_size", value= "10"),
// default name : hibernate_sequence
@Parameter(name = "prefer_sequence_per_entity", value= "false"),
@Parameter(name = "optimizer", value="pooled")
},
strategy = "org.hibernate.id.enhanced.SequenceStyleGenerator")
@Column(name = "ID", nullable = false)
private Long id;

在 hibernate 5.2 中,它可以按预期工作,但在 hibernate 5.3 中不再工作。

迁移指南在这里:https://github.com/hibernate/hibernate-orm/blob/5.3/migration-guide.adoc 不引用序列生成器的任何更改。

可能是什么问题?

我发现这是休眠5.3的新行为:

在方法SequenceStyleGenerator.determineSequenceName中添加了该代码:

final Boolean preferGeneratorNameAsDefaultName = serviceRegistry.getService( ConfigurationService.class )
.getSetting( AvailableSettings.PREFER_GENERATOR_NAME_AS_DEFAULT_SEQUENCE_NAME, StandardConverters.BOOLEAN, true );
if ( preferGeneratorNameAsDefaultName ) {
final String generatorName = params.getProperty( IdentifierGenerator.GENERATOR_NAME );
if ( StringHelper.isNotEmpty( generatorName ) ) {
fallbackSequenceName = generatorName;
}
}

新的默认行为是使用生成器名称作为序列名称。因此,从休眠 5.2 迁移到 5.3 有两种可能性:

  • 将生成器名称更改为序列名称
  • 通过在休眠配置(或生成器参数(中将hibernate.model.generator_name_as_sequence_name设置为false,恢复到不使用生成器名称的休眠 5.2- 行为

您的生成器名称被解释为属于特定架构,重命名应该可以解决此问题 - 避免使用点。

请查看手册第 2.6.11 节,了解如何命名和参数化发电机:https://docs.jboss.org/hibernate/stable/orm/userguide/html_single/Hibernate_User_Guide.html

最新更新