簡體   English   中英

Hibernate的屬性hibernate.default_schema無法正常工作

[英]Hibernate's property hibernate.default_schema is not working properly

我想添加在本機查詢中使用的參數化數據庫名稱我引用此URL來實現https://vladmihalcea.com/how-to-resolve-the-hibernate-global-database-schema-and-catalog-for-native -sql-queries /我已經在階段測試並測試了environemnt,除了數據庫名稱缺失外,一切正常。 以下是我的代碼

application.yml

hibernate:
show_sql: true
format_sql: true
dialect: org.hibernate.dialect.MySQLDialect
hbm2ddl.auto: false
default_schema: student

SummitRepository.java

@Query(value = "select * from {h-schema}summit", nativeQuery = true)
public List<Summit> getActiveUpcomingSummitsForChannelIds();

TestDbConfig

public class TestDbConfig {  

    @Primary
    @Bean
    public LocalContainerEntityManagerFactoryBean entityManagerFactory() {

        HibernateJpaVendorAdapter hibernateJpa = new HibernateJpaVendorAdapter();
        hibernateJpa.setDatabasePlatform(env
                .getRequiredProperty("hibernate.dialect"));
        hibernateJpa.setShowSql(env.getRequiredProperty("hibernate.show_sql",
                Boolean.class));

        LocalContainerEntityManagerFactoryBean emf = new LocalContainerEntityManagerFactoryBean();
        emf.setDataSource(datasource());
        emf.setJpaVendorAdapter(hibernateJpa);
        emf.setPackagesToScan("com.xxx.student.model");
        Map<String, String> jpaProps = new HashMap<String, String>();

        jpaProps.put("hibernate.dialect",
                env.getRequiredProperty("hibernate.dialect"));
        jpaProps.put("hibernate.format_sql",
                env.getRequiredProperty("hibernate.format_sql"));
        jpaProps.put("hibernate.hbm2ddl.auto",
                env.getRequiredProperty("hibernate.hbm2ddl.auto"));
        jpaProps.put("hibernate.show_sql",
                env.getRequiredProperty("hibernate.show_sql"));
        ***jpaProps.put("hibernate.default_schema",
                env.getRequiredProperty("hibernate.default_schema"));***

        emf.setJpaPropertyMap(Collections.singletonMap(
                "javax.persistence.validation.mode", "none"));
        return emf;
    }

Hibernate背景生成的查詢

 select * from summit

實際產出

select * from summit

預期產出

select * from student.summit

數據庫名稱丟失。 我哪里錯了? 先謝謝你。

在persistence.xml文件中指定默認架構:

<property name="hibernate.default_schema" value="yourSchemaName" />

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM