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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM