首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Spring Boot Hibernate自动配置与手动注释配置

Spring Boot Hibernate自动配置与手动注释配置
EN

Stack Overflow用户
提问于 2018-05-16 04:26:48
回答 1查看 1.3K关注 0票数 0

我有一个Spring Boot Web应用程序,它尝试使用Hibernate访问我的数据库。我还有一个不同的、没有spring启动的应用程序,它试图访问相同的数据库。

我正在尝试使用自动配置方法配置spring boot应用程序,在application.properties文件中定义我的DB属性。

我正在使用带注释的类配置none spring boot应用程序。

由于某些原因,Spring Boot自动配置的行为与带注释的类配置不同。

如果我第一次连接到数据库并使用hibernate ddl创建模式,然后使用另一种配置方法重新连接,我会得到ddl错误,例如枚举列停止工作。

有人能解释一下为什么我使用spring和hibernate的两种配置方式得到不同的行为吗?我如何让它们以相同的方式运行?这是否与ejb命名策略属性有关?

以下是我配置JPA的两种方式:

application.properties:

代码语言:javascript
复制
spring.datasource.url=jdbc:hsqldb:file:databaseFiles/hibData/;hsqldb.write_delay_millis=0
spring.datasource.root=sa
spring.datasource.password=1
spring.datasource.driverClassName=org.hsqldb.jdbcDriver


spring.jpa.properties.hibernate.current_session_context_class=org.springframework.orm.hibernate5.SpringSessionContext
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.HSQLDialect
spring.jpa.properties.hibernate.show_sql=true
spring.jpa.properties.hibernate.hbm2ddl.auto=update
spring.jpa.properties.hibernate.jdbc.batch_size=50
spring.jpa.properties.hibernate.order_inserts=true
spring.jpa.properties.hibernate.order_updates=true
spring.jpa.properties.hibernate.jdbc.batch_versioned_data=true

配置类:

代码语言:javascript
复制
import org.apache.commons.dbcp.BasicDataSource;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.annotation.EnableTransactionManagement;

import javax.persistence.EntityManagerFactory;
import javax.sql.DataSource;
import java.util.Properties;


@Configuration
@EnableTransactionManagement
public class DatabaseHibConfig {

    @Bean
    public DataSource getDataSource(){
            BasicDataSource ds = new BasicDataSource();
            ds.setDriverClassName("org.hsqldb.jdbcDriver");
            ds.setUrl("jdbc:hsqldb:file:databaseFiles/hibData/;hsqldb.write_delay_millis=0");
            ds.setUsername("sa");
            ds.setPassword("1");
            return ds;
    }

    @Bean
    public PlatformTransactionManager transactionManager(EntityManagerFactory entityManagerFactory, DataSource dataSource){
        JpaTransactionManager jpaTransactionManager = new JpaTransactionManager();
        jpaTransactionManager.setDataSource(dataSource);
        jpaTransactionManager.setEntityManagerFactory(entityManagerFactory);
        return jpaTransactionManager;
    }

    @Bean
    LocalContainerEntityManagerFactoryBean entityManagerFactory(DataSource dataSource) {
        LocalContainerEntityManagerFactoryBean entityManagerFactoryBean = new LocalContainerEntityManagerFactoryBean();
        entityManagerFactoryBean.setDataSource(dataSource);
        entityManagerFactoryBean.setJpaVendorAdapter(new HibernateJpaVendorAdapter());
        entityManagerFactoryBean.setPackagesToScan("mediabeast.data.hibernate.model");

        Properties jpaProperties = new Properties();

        jpaProperties.put("hibernate.dialect", "org.hibernate.dialect.HSQLDialect");

        jpaProperties.put("hibernate.hbm2ddl.auto","update");

        jpaProperties.put("hibernate.show_sql","true");

        entityManagerFactoryBean.setJpaProperties(jpaProperties);

        return entityManagerFactoryBean;
    }
}
EN

回答 1

Stack Overflow用户

发布于 2018-05-16 19:22:13

将以下属性添加到两个配置中似乎可以修复导致代码无法工作的错误。

代码语言:javascript
复制
spring.jpa.properties.hibernate.physical_naming_strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
spring.jpa.properties.hibernate.implicit_naming_strategy=org.hibernate.boot.model.naming.ImplicitNamingStrategyJpaCompliantImpl

然而,在切换配置时,我仍然在启动时收到“对象已经存在”的ddl错误。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50358673

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档