当我们的项目里有多种数据源时,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的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文件都添加@Mapper注解,这些重复的工作可以使用MapperScan来完成。
@SpringBootApplication @MapperScan("com.lind.basic.mapper") public class BasicApplication {}
最后,在使用h2数据库时,需要注意它的语法与mysql略有不同,像对日期时间函数的支持,我们在开发时就要特别注意。
SELECT * FROM subscriptions WHERE active_until >= (DATE_SUB(CURDATE(), INTERVAL 3 DAY)) AND active_until <= (DATE_ADD(CURDATE(), INTERVAL 1 DAY)) AND status = "ACTIVE"
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