Springboot~多個數(shu)據(ju)源(yuan)時自定義datasource的bean
當(dang)我們(men)的(de)項(xiang)目里有多種數據源時(shi),mysql,h2,mongodb,es等等,這時(shi)你需要為每種數據源添加(jia)自己的(de)bean類,在(zai)bean里構(gou)建配置,而直接在(zai)yml里的(de)配置往(wang)往(wang)會(hui)出現循環引(yin)用的(de)問題(ti)。
org.springframework.beans.factory.BeanCurrentlyInCreationException: Error creating bean with name 'scopedTarget.dataSource': Requested bean is currently in creation: Is there an unresolvable circular reference?
有(you)時(shi),也(ye)(ye)會出現其(qi)它(ta)奇葩的問題,總之,當你的項(xiang)目里數據源比較多(duo)時(shi),通過配置(zhi)文件+profile來管理它(ta)們更清(qing)晰,也(ye)(ye)不容易出錯(cuo)。
為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;
}
}
上面的配(pei)置類里,聲明了一個h2專有的bean,主要用在test環境里,因為test環境應(ying)該是不(bu)能訪問外網的,這樣(yang)才(cai)能保證測(ce)試的客觀(guan)性(xing)。
mybatis自動掃描mapper
對于mybatis框架來說,沒必要沒有mapper文件都(dou)添加@Mapper注解,這些重復的工作(zuo)可以使用(yong)MapperScan來完成。
@SpringBootApplication
@MapperScan("com.lind.basic.mapper")
public class BasicApplication {}
最后,在使用h2數據庫時,需要注(zhu)意它的語(yu)法與mysql略有不同,像對日期時間函數的支(zhi)持(chi),我(wo)們(men)在開發時就要特別注(zhu)意。
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'
對于(yu)H2數據(ju)庫(ku)來(lai)說,to_days,date_add,date_diff都是不支持(chi)的,需要(yao)用TIMESTAMPADD,TIMESTAMPDIFF來(lai)代替.
參考文章: