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的总结
- 这个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"
- 把这个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
合集:
springboot(1)
分类:
Java
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2014-03-19 DDD~领域事件中使用分布式事务
2014-03-19 MVVM架构~knockoutjs系列之表单添加(验证)与列表操作源码开放
2013-03-19 说说IUnitOfWork~DbContext对象的创建应该向BLL层公开
2013-03-19 Yslow-23条规则
2010-03-19 对于百万条数据进行查询:自己对2万条数据进行的测试,答案是。。。
2010-03-19 知方可补不足~说说吧!timestamp有什么用?