Java 每个实体的Hibernate命名策略
我有一个全局命名策略,但对于一些实体,我想使用不同的策略。在jpa或hibernate中可能吗Java 每个实体的Hibernate命名策略,java,hibernate,jpa,Java,Hibernate,Jpa,我有一个全局命名策略,但对于一些实体,我想使用不同的策略。在jpa或hibernate中可能吗 澄清:我不想使用@Table(name=“xxx”)或@Column(name=“xxx”)。我问的是命名策略组件(这里举例说明:)。这是一个为您推断列和表名的组件我在Hibernate源代码中看不到任何方法。EntityBinder使用ObjectNameNormalizer.NamingStrategyHelper来命名,它从Configuration.namingStrategy(全局策略)或通
澄清:我不想使用@Table(name=“xxx”)或@Column(name=“xxx”)。我问的是命名策略组件(这里举例说明:)。这是一个为您推断列和表名的组件我在Hibernate源代码中看不到任何方法。
EntityBinder
使用ObjectNameNormalizer.NamingStrategyHelper
来命名,它从Configuration.namingStrategy
(全局策略)或通过MetadataImpl
的复杂路径获取命名策略,而该路径没有任何用途
因此,您可能需要手动覆盖字段名。我甚至看不到一个明显的方法来获取这个领域的背景,所以我认为即使是大脑分裂命名策略看起来也不可能
更新:看到@anthony accioly的答案后,我想最后一句可能是错的。所以我测试了它如下
package internal.sandbox.domain;
@Entity
public class SomeEntity {
private String id;
private String someField;
@Id
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getSomeField() {
return someField;
}
public void setSomeField(String someField) {
this.someField = someField;
}
}
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories("internal.sandbox.dao")
@Import(DataSourceConfiguration.class)
public class JpaConfiguration {
@Bean
@Autowired
public LocalContainerEntityManagerFactoryBean localContainerEntityManagerFactoryBean(DataSource dataSource) {
HibernateJpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
vendorAdapter.setDatabasePlatform("org.hibernate.dialect.PostgreSQL82Dialect");
vendorAdapter.setDatabase(Database.POSTGRESQL);
LocalContainerEntityManagerFactoryBean factory = new LocalContainerEntityManagerFactoryBean();
factory.setJpaVendorAdapter(vendorAdapter);
factory.setPackagesToScan("internal.sandbox"); // note, no ".domain"
factory.setDataSource(dataSource);
Properties properties = new Properties();
properties.setProperty("hibernate.cache.use_second_level_cache", "false");
properties.setProperty("hibernate.ejb.naming_strategy", "org.hibernate.cfg.ImprovedNamingStrategy");
factory.setJpaProperties(properties);
return factory;
}
...
public interface SomeEntityDao extends CrudRepository<SomeEntity, String> {
}
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {ApplicationConfiguration.class, JpaConfiguration.class})
public class SomeEntityDaoIntegrationTests {
@Autowired
private SomeEntityDao someEntityDao;
@Test
public void testSave() {
SomeEntity someEntity = new SomeEntity();
someEntity.setId("foo");
someEntity.setSomeField("bar");
this.someEntityDao.save(someEntity);
}
}
使用jpa配置
,如下所示
package internal.sandbox.domain;
@Entity
public class SomeEntity {
private String id;
private String someField;
@Id
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getSomeField() {
return someField;
}
public void setSomeField(String someField) {
this.someField = someField;
}
}
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories("internal.sandbox.dao")
@Import(DataSourceConfiguration.class)
public class JpaConfiguration {
@Bean
@Autowired
public LocalContainerEntityManagerFactoryBean localContainerEntityManagerFactoryBean(DataSource dataSource) {
HibernateJpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
vendorAdapter.setDatabasePlatform("org.hibernate.dialect.PostgreSQL82Dialect");
vendorAdapter.setDatabase(Database.POSTGRESQL);
LocalContainerEntityManagerFactoryBean factory = new LocalContainerEntityManagerFactoryBean();
factory.setJpaVendorAdapter(vendorAdapter);
factory.setPackagesToScan("internal.sandbox"); // note, no ".domain"
factory.setDataSource(dataSource);
Properties properties = new Properties();
properties.setProperty("hibernate.cache.use_second_level_cache", "false");
properties.setProperty("hibernate.ejb.naming_strategy", "org.hibernate.cfg.ImprovedNamingStrategy");
factory.setJpaProperties(properties);
return factory;
}
...
public interface SomeEntityDao extends CrudRepository<SomeEntity, String> {
}
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {ApplicationConfiguration.class, JpaConfiguration.class})
public class SomeEntityDaoIntegrationTests {
@Autowired
private SomeEntityDao someEntityDao;
@Test
public void testSave() {
SomeEntity someEntity = new SomeEntity();
someEntity.setId("foo");
someEntity.setSomeField("bar");
this.someEntityDao.save(someEntity);
}
}
Spring数据DAO如下所示
package internal.sandbox.domain;
@Entity
public class SomeEntity {
private String id;
private String someField;
@Id
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getSomeField() {
return someField;
}
public void setSomeField(String someField) {
this.someField = someField;
}
}
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories("internal.sandbox.dao")
@Import(DataSourceConfiguration.class)
public class JpaConfiguration {
@Bean
@Autowired
public LocalContainerEntityManagerFactoryBean localContainerEntityManagerFactoryBean(DataSource dataSource) {
HibernateJpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
vendorAdapter.setDatabasePlatform("org.hibernate.dialect.PostgreSQL82Dialect");
vendorAdapter.setDatabase(Database.POSTGRESQL);
LocalContainerEntityManagerFactoryBean factory = new LocalContainerEntityManagerFactoryBean();
factory.setJpaVendorAdapter(vendorAdapter);
factory.setPackagesToScan("internal.sandbox"); // note, no ".domain"
factory.setDataSource(dataSource);
Properties properties = new Properties();
properties.setProperty("hibernate.cache.use_second_level_cache", "false");
properties.setProperty("hibernate.ejb.naming_strategy", "org.hibernate.cfg.ImprovedNamingStrategy");
factory.setJpaProperties(properties);
return factory;
}
...
public interface SomeEntityDao extends CrudRepository<SomeEntity, String> {
}
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {ApplicationConfiguration.class, JpaConfiguration.class})
public class SomeEntityDaoIntegrationTests {
@Autowired
private SomeEntityDao someEntityDao;
@Test
public void testSave() {
SomeEntity someEntity = new SomeEntity();
someEntity.setId("foo");
someEntity.setSomeField("bar");
this.someEntityDao.save(someEntity);
}
}
我在ImprovedNamingStrategy
中设置了断点,用“SomeEntity”调用了classToTableName()
,用“someField”调用了propertyToColumnName()
换句话说,包信息没有被传入,因此至少在这个设置中,它不能用于基于包名称应用不同的命名策略。那么@Entity(name=“yourNameHere”)
呢?你的命名策略还意味着什么?请澄清。我所说的命名策略是指“避免手动提供列名的方法”:piotrek,我想大家的观点是。对默认用例使用全局命名策略,并使用注释覆盖非默认用例。If将比实现您自己的更干净。我想做global=ImprovedNamingStrategy和class A中的set-SimpleNameingStrategy。我不想写我的信own@piotrek,我理解你的问题,我告诉你的是,你的选择是:1)选择ImprovedNamingStrategy
作为默认值,并使用标准JPA注释自定义class A,或2)自己制作NamingStrategy
以将不同的实体委托给不同的命名约定。后者是不可取的,除非您真的有很多实体需要通过每个命名策略(自制或非自制)进行处理。