springboot2.0, 多数据源,连接mysql和postgresql的一个坑

作者的应用有多个数据源,两个pg和,一个mysql
如果应用第一个初始化的数据源是pg,那应用就会一直使用pg的dialect继续初始化之后的数据源
必须在mysql的数据源配置类中手动指定为mysql的dialect
网上大多数是在配置文件中指定
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
如果你的数据源都是同一类型,就不会有问题

private Map<String, Object> getVendorProperties() {
        Map<String, Object> ret = jpaProperties.getHibernateProperties(new HibernateSettings());
        ret.put("hibernate.dialect", "org.hibernate.dialect.MySQL5InnoDBDialect");
        return ret;
    }

    /**
     * 设置实体类所在位置
     */
    @Bean(name = "entityManagerFactoryJeecms")
    public LocalContainerEntityManagerFactoryBean entityManagerFactoryJeecms(EntityManagerFactoryBuilder builder) {
        return builder.dataSource(jeecmsDataSource).packages("com.zupu.core.jeecms.domain")
                .persistenceUnit("jeecmsPersistenceUnit").properties(getVendorProperties()).build();
    }
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,999评论 6 342
  • 本文中我们介绍并比较两种最流行的开源持久框架:iBATIS和Hibernate,我们还会讨论到Java Persi...
    大同若鱼阅读 4,378评论 4 27
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,269评论 19 139
  • 小城市姑凉到了大城市的迷茫与无助,再到人心复杂的职场,再到有妇之夫对单纯女孩的利用,我终于从不谙世事的小姑凉变成了...
    忘浮城阅读 157评论 0 0
  • 今天是备战的最后一天。明天要考核了,一直鼓励让自己不紧张,做好准备就行,让自己放松。该吃吃该睡睡。 晚上睡前并没有...
    小莎妹儿阅读 350评论 0 0