网站大量收购独家精品文档,联系QQ:2885784924

Spring动态创建,加载,使用多数据源.docx

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

550008333 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档