Spring配置多数据源

1. 首先在配置文件中配置多个dataSource
2. 扩展spring的AbstractRoutingDataSource抽象类,实现动态数据源
AbstractRoutingDataSource中的抽象方法determineCurrentLookupKey是实现数据源的route的核心.这里对该方法进行Override。

上下文DbContextHolder为一线程安全的ThreadLocal,具体代码如下:

3. 配置动态数据源
将DynamicDataSource Bean加入到Spring的上下文xml配置文件中去,同时配置DynamicDataSource的targetDataSources(多数据源目标)属性的Map映射。

4. 使用动态数据源
DynamicDataSource是继承与AbstractRoutingDataSource,而AbstractRoutingDataSource又是继承于org.springframework.jdbc.datasource.AbstractDataSource,AbstractDataSource实现了统一的DataSource接口,所以DynamicDataSource同样可以当一个DataSource使用。

5. 动态数据源的管理
如何选择控制每个业务中需要的具体数据源,可是使用手动控制:

如果在service层有比较统一的规则的话,也可以使用aop设置数据源使用。
6. 这里一般都是一个service一个数据源,所以最好使用aop在service层执行完之后统一调用

清空数据源信息。
当然,在上面配置里面有个参数defaultTargetDataSource为默认数据源,就是不设置数据源的话,就是用这个数据源。

©原创文章,转载请注明来源: 赵伊凡's Blog
©本文链接地址: Spring配置多数据源

“Spring配置多数据源”的34个回复

  1. Pingback: Blue Coaster33
  2. Pingback: best online casinos
  3. Pingback: tvpackages.net
  4. Pingback: lane penge nu
  5. Pingback: car parking
  6. Pingback: mobile porn movies
  7. Pingback: laan penge billigt
  8. Pingback: water ionizers
  9. Pingback: YouTube views kopen
  10. Pingback: car parking
  11. Pingback: water ionizer loan
  12. Pingback: paypal loans
  13. Pingback: useful site
  14. Pingback: locksmith n ft myers
  15. Pingback: plumbing supplies
  16. Pingback: plumber snake rental
  17. Pingback: house blue
  18. Pingback: a cool way to improve
  19. Pingback: HD Coloring Pages
  20. Pingback: ionizer loans
  21. Pingback: alkaline water brands
  22. Pingback: water ionizer
  23. Pingback: electricity
  24. Pingback: water ionizer loans
  25. Pingback: alkaline water
  26. Pingback: click this
  27. Pingback: alkaline water
  28. Pingback: this post

发表评论

电子邮件地址不会被公开。 必填项已用*标注