Oracleのバックエンドがありますが、この同じ問題がHibernate 5に移行しました。私は、org.hibernate.boot.model.naming.ImplicitNamingStrategy
とorg.hibernate.boot.model.naming.PhysicalNamingStrategy
の両方を利用して、Hibernate 4と同じ名前付け戦略を達成することができました。ここで
は私の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