我有这个问题迁移到Hibernate 5,尽管我们有一个Oracle后端。通过使用org.hibernate.boot.model.naming.ImplicitNamingStrategy
和org.hibernate.boot.model.naming.PhysicalNamingStrategy
,我能够实现类似的命名策略。
这里是我的bean定义看起来像我的应用程序上下文:
@Bean
@Primary
public static JpaProperties jpaProperties() {
final Map<String, String> hibernateConfig = newHashMap();
hibernateConfig.put("hibernate.implicit_naming_strategy",
"org.hibernate.boot.model.naming.ImplicitNamingStrategyLegacyHbmImpl");
hibernateConfig.put("hibernate.physical_naming_strategy",
"com.anyapp.CustomNamingStrategy");
final JpaProperties jpaProperties = new JpaProperties();
jpaProperties.setProperties(hibernateConfig);
jpaProperties.setDatabase(ORACLE);
jpaProperties.setDatabasePlatform(ORACLE12C_DIALECT);
jpaProperties.setGenerateDdl(false);
jpaProperties.setShowSql(false);
return jpaProperties;
}
最讨厌的部分是找出哪些命名策略,以何种方式申请,事实上,我不得不实施CustomNamingStrategy
上我自己的,因为Hibernate没有提供与传统ImprovedNamingStrategy
的命名相匹配的PhysicalNamingStrategy
。
这里是我CustomNamingStrategy
内容:
package com.anyapp;
import org.apache.commons.lang.StringUtils;
import org.hibernate.boot.model.naming.Identifier;
import org.hibernate.boot.model.naming.PhysicalNamingStrategy;
import org.hibernate.engine.jdbc.env.spi.JdbcEnvironment;
public class CustomNamingStrategy implements PhysicalNamingStrategy {
@Override
public Identifier toPhysicalCatalogName(Identifier identifier, JdbcEnvironment jdbcEnv) {
return convert(identifier);
}
@Override
public Identifier toPhysicalColumnName(Identifier identifier, JdbcEnvironment jdbcEnv) {
return convert(identifier);
}
@Override
public Identifier toPhysicalSchemaName(Identifier identifier, JdbcEnvironment jdbcEnv) {
return convert(identifier);
}
@Override
public Identifier toPhysicalSequenceName(Identifier identifier, JdbcEnvironment jdbcEnv) {
return convert(identifier);
}
@Override
public Identifier toPhysicalTableName(Identifier identifier, JdbcEnvironment jdbcEnv) {
return convert(identifier);
}
private Identifier convert(Identifier identifier) {
if (identifier == null || StringUtils.isBlank(identifier.getText())) {
return identifier;
}
String regex = "([a-z])([A-Z])";
String replacement = "$1_$2";
String newName = identifier.getText().replaceAll(regex, replacement).toLowerCase();
return Identifier.toIdentifier(newName);
}
}
您可能需要调整正则表达式,以适应您的需求,但是这是对我工作。
我同意了,在我看来,Hibernate并没有一个符合其原有命名策略的物理命名策略。你能否分享你的com.anyapp.CustomNamingStrategy? –
我已将我的CustomNamingStrategy实现的内容添加到我的答案中 – lax1089