Springboot~多个数据源时自定义datasource的bean

当我们的项目里有多种数据源时,mysql,h2,mongodb,es等等,这时你需要为每种数据源添加自己的bean类,在bean里构建配置,而直接在yml里的配置往往会出现循环引用的问题。

org.springframework.beans.factory.BeanCurrentlyInCreationException: Error creating bean with name 'scopedTarget.dataSource': Requested bean is currently in creation: Is there an unresolvable circular reference?

有时,也会出现其它奇葩的问题,总之,当你的项目里数据源比较多时,通过配置文件+profile来管理它们更清晰,也不容易出错。

为h2添加配置bean

/**
 * 多数据源时,H2的datasource声明
 */
@Configuration
@ActiveProfiles("test")
public class H2Mock {
  @Value("${h2.dbName:Test1}")
  String dbName;
  @Value("${h2.dbSchema:db/schema.sql}")
  String dbSchema;

  @Bean
  EmbeddedDatabaseFactoryBean dataSource() {
    EmbeddedDatabaseFactoryBean factoryBean = new EmbeddedDatabaseFactoryBean();
    factoryBean.setDatabaseType(EmbeddedDatabaseType.H2);
    factoryBean.setDatabaseName(dbName);
    factoryBean.setDatabasePopulator(new ResourceDatabasePopulator(
        new ClassPathResource(dbSchema)
    ));

    return factoryBean;

  }
}

上面的配置类里,声明了一个h2专有的bean,主要用在test环境里,因为test环境应该是不能访问外网的,这样才能保证测试的客观性。

mybatis自动扫描mapper

对于mybatis框架来说,没必要没有mapper文件都添加@Mapper注解,这些重复的工作可以使用MapperScan来完成。

@SpringBootApplication
@MapperScan("com.lind.basic.mapper")
public class BasicApplication {}

最后,在使用h2数据库时,需要注意它的语法与mysql略有不同,像对日期时间函数的支持,我们在开发时就要特别注意。

h2和mysql的总结

  1. 这个mysql函数在h2里是不支持的
SELECT *
FROM subscriptions
WHERE active_until >= (DATE_SUB(CURDATE(), INTERVAL 3 DAY))
AND active_until <= (DATE_ADD(CURDATE(), INTERVAL 1 DAY))
AND status = "ACTIVE"
  1. 把这个Date_Add换成这个TIMESTAMPADD就好了
SELECT *
FROM subscriptions
WHERE active_until >= (TIMESTAMPDIFF(DAY, 3, CURRENT_DATE))
AND active_until <= (TIMESTAMPADD(DAY, 1, CURRENT_DATE))
AND status LIKE 'ACTIVE'

对于H2数据库来说,to_days,date_add,date_diff都是不支持的,需要用TIMESTAMPADD,TIMESTAMPDIFF来代替.

参考文章https://stackoverflow.com/questions/37304314/date-sub-and-date-add-in-h2-for-mysql

原文 

http://www.cnblogs.com/lori/p/12525823.html

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » Springboot~多个数据源时自定义datasource的bean

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址