- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Spring动态创建,加载,使用多数据源
发表于2年前(2014-02-26 18:00)?? 阅读(2970)?|?评论( 2)?41人收藏此文章,? \o 添加到收藏夹 我要收藏
赞1
9月19日成都 OSC 源创会正在报名,送机械键盘和开源无码内裤??
摘要?项目中我们经常会遇到多数据源的问题,尤其是数据同步或定时任务等项目更是如此。多数据源让人最头痛的,不是配置多个数据源,而是如何能灵活动态的切换数据源。
? ? ? 项目中我们经常会遇到多数据源的问题,尤其是数据同步或定时任务等项目更是如此。多数据源让人最头痛的,不是配置多个数据源,而是如何能灵活动态的切换数据源。例如在一个spring和hibernate的框架的项目中,我们在spring配置中往往是配置一个dataSource来连接数据库,然后绑定给sessionFactory,在dao层代码中再指定sessionFactory来进行数据库操作。
正如上图所示,每一块都是指定绑死的,如果是多个数据源,也只能是下图中那种方式。
可看出在Dao层代码中写死了两个SessionFactory,这样日后如果再多一个数据源,还要改代码添加一个SessionFactory,显然这并不符合开闭原则。
那么正确的做法应该是
先说一下我的思路:
首先做一个创建数据源配置文件的类,专门用于创建数据源xml配置,叫ConfigFileCreator.java?
其次,编写一个动态加载刚才创建的配置文件的类,叫?DynamicLoadBean.java。至此,创建的数据源到内存中已经完成。
第三,重点编写这个DynamicDataSource.java,该类主要是用来实现动态切换数据源,并通知容器。在这一块我选择了修改,AbstractRoutingDataSource.java,编写一个支持添加数据源对象的方法public void addDataSource(Object key,Object dataSource)
第四,写例子来测试
实现过程如下:
1.bean.xml配置文件
[html]? ?? view plain??? copy????????
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
?xml?version=1.0?encoding=UTF-8???
beans?xmlns=/schema/beans??
????xmlns:xsi=/2001/XMLSchema-instance??
????xmlns:tx=/schema/tx??
????xmlns:context=/schema/context??
????xsi:schemaLocation=/schema/beans?/schema/beans/spring-beans-3.0.xsd??
????????????????/schema/context?/schema/context/spring-context-3.0.xsd??
????????????????/schema/tx?/schema/tx/spring-tx-3.0.xsd??
????!--?自动扫描与装配bean?--??
????context:component-scan?base-package=qilin/context:component-scan??
????!--?使用外部的配置文件?--??
????context:property-placeholder?location=classpath:perties?/??
????bean?id=defaultDataSource?class=com.mchange.v2.c3p0.ComboPooledDataSource??
????????????????!--?数据库连接信息?--??
????????????????property?name=jdbcUrl?value=${jdbcUrl}/property??
????????????????property?name=driverClass?value=${driverClass}/property??
????????????????property?name=user?value=${username}/property??
???????????
文档评论(0)