zoukankan      html  css  js  c++  java
  • Spring Boot——jpaProperties.getHibernateProperties()的使用

    背景

    • 在使用SpringBoot配置多数据源时,找到了很多大牛的资料,结果在使用jpaProperties.getHibernateProperties()时一直报错。
    • 很多资料写法如下,可是我这里就行不通
      • @Primary
            @Bean(name = "entityManagerFactoryPrimary")
            public LocalContainerEntityManagerFactoryBean entityManagerFactoryPrimary(EntityManagerFactoryBuilder builder) {
                return builder
                        .dataSource(primaryDataSource)// 设置数据源
                        .properties(jpaProperties.getProperties())// 设置jpa配置
                        .properties(getVendorProperties())// 设置hibernate配置
                        .packages("com.xxxx.xxxxxx.xxxxxx.xxxxx.entities.superviser") //设置实体类所在位置
                        .persistenceUnit("primaryPersistenceUnit")// 设置持久化单元名,用于@PersistenceContext注解获取EntityManager时指定数据源
                        .build();
            }
        
            private Map getVendorProperties() {
                return jpaProperties.getHibernateProperties(new HibernateSettings());
            }

    原因

    • 我使用的SpringBoot版本是2.2.1 RELEASE 版本,这个getHibernateProperties()方法已经被PASS掉了。

    解决办法

    • 曲线救国,使用如下代码即可
      • @Primary
            @Bean(name = "entityManagerFactoryPrimary")
            public LocalContainerEntityManagerFactoryBean entityManagerFactoryPrimary(EntityManagerFactoryBuilder builder) {
                return builder
                        .dataSource(primaryDataSource)// 设置数据源
                        .properties(jpaProperties.getProperties())// 设置jpa配置
                        .properties(getVendorProperties())// 设置hibernate配置
                        .packages("com.canaan.superviser.objects.rpc.entities.superviser") //设置实体类所在位置
                        .persistenceUnit("primaryPersistenceUnit")// 设置持久化单元名,用于@PersistenceContext注解获取EntityManager时指定数据源
                        .build();
            }
        
        
            private Map getVendorProperties() {
                return hibernateProperties.determineHibernateProperties(jpaProperties.getProperties(), new HibernateSettings());
        
        //        return jpaProperties.getHibernateProperties(new HibernateSettings());
            }
  • 相关阅读:
    《TCP/IP详解》读书笔记
    更改vsts源代码绑定服务器地址方法
    t-sql或mssql怎么用命令行导入数据脚本
    t-sql中字符串前加N代表什么意思
    C#连接mariadb代码及方式
    sp_executesql动态执行sql语句并将结果赋值给一变量
    mariadb配置允许远程访问方式
    将DataTable转换为List,将List转换为DataTable的实现类
    SQL update select语句
    怎么区分MSSQL中nvarchar和varchar的区别?
  • 原文地址:https://www.cnblogs.com/zuiyue_jing/p/12757555.html
Copyright © 2011-2022 走看看