After some research , referring to these post i tried setting the custom naming strategy
JPA column with incorrect underscore
Here is my custom naming Strategy
public class CustomPhysicalNamingStrategy implements PhysicalNamingStrategy {
@Override
public Identifier toPhysicalCatalogName(final Identifier identifier, final JdbcEnvironment jdbcEnv) {
return convertToSnakeCase(identifier);
}
@Override
public Identifier toPhysicalColumnName(final Identifier identifier, final JdbcEnvironment jdbcEnv) {
return convertToSnakeCase(identifier);
}
@Override
public Identifier toPhysicalSchemaName(final Identifier identifier, final JdbcEnvironment jdbcEnv) {
return convertToSnakeCase(identifier);
}
@Override
public Identifier toPhysicalSequenceName(final Identifier identifier, final JdbcEnvironment jdbcEnv) {
return convertToSnakeCase(identifier);
}
@Override
public Identifier toPhysicalTableName(final Identifier identifier, final JdbcEnvironment jdbcEnv) {
return convertToSnakeCase(identifier);
}
private Identifier convertToSnakeCase(final Identifier identifier) {
final String regex = "([a-z])([A-Z])";
final String replacement = "$1_$2";
final String newName = identifier.getText().replaceAll(regex, replacement).toLowerCase();
return Identifier.toIdentifier(newName);
}
LocalContainerEntityManagerFactoryBean :
@Bean
public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
LocalContainerEntityManagerFactoryBean localContainerEntityManagerFactoryBean = new LocalContainerEntityManagerFactoryBean();
localContainerEntityManagerFactoryBean.setDataSource(dataSource());
localContainerEntityManagerFactoryBean.setPackagesToScan(basePackage);
JpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
localContainerEntityManagerFactoryBean.setJpaVendorAdapter(vendorAdapter);
localContainerEntityManagerFactoryBean.setJpaProperties(customProperties());
return localContainerEntityManagerFactoryBean;
}
customProperties()
Properties customProperties() {
Properties properties = new Properties();
properties.setProperty("hibernate.dialect",
ResourceConfig.getProperties().getProperty(PropertyConstants.SPRING_JPA_HIBERNATE_DIALECT));
properties.setProperty("hibernate.hbm2ddl.auto", ddl);
properties.setProperty("hibernate.show_sql", showSQL);
properties.setProperty("hibernate.temp.use_jdbc_metadata_defaults", metaDataDefaults);
properties.setProperty("hibernate.jdbc.lob.non_contextual_creation", contextualCreation);
properties.setProperty("hibernate.physical_naming_strategy", "com.config.CustomPhysicalNamingStrategy");
return properties;
}
But when starting the springboot application it throwst the below exception :
Caused by: java.lang.NullPointerException
at com.config.CustomPhysicalNamingStrategy.convertToSnakeCase(CustomPhysicalNamingStrategy.java:47)
Exaclty to the line in CustomPhysicalNamingStrategy
final String newName = identifier.getText().replaceAll(regex, replacement).toLowerCase();
did i miss some configuration, or am i doing it in a wrong way?
Using spring boot - 2.2.4.RELEASE