mybatis源代码分析之org.apache.ibatis.datasource包

注:本篇笔记用于初步记录,而后再进行详细整理

 

这个包整体是一个工厂模式,所处理的产品就是datasource,mybatis中可以使用三种类型的数据源(http://mybatis.github.io/mybatis-3/configuration.html#environments):UNPOOLEDPOOLED、JNDI 。但在这个包中只有两个具体的产品:UnpooledDataSource、PooledDataSourceFactory。因为Jndi类型的数据源是在配置文件中配置好的,使用时只需要执行如下的代码:

Context ic = new InitialContext();

DataSource source = (DataSource)ic.lookup("java:comp/env/jdbc/books");

即可获取到数据源。


这个包中有一个抽象工厂DataSourceFactory,尽管Jndi类型的数据库没有具体的产品类对应,但仍然有具体的工厂类:UnpooledDataSourceFactory、PooledDataSourceFactory和JndiDataSourceFactory。

当然这个包中不只是几个工厂类和产品类,还有相对应的一些辅助类。

com.zd.archives.common.utils.ContextUtils.getDataSourceKey(ContextUtils.java:357) -http-nio-8080-exec-6-getDataSourceKey fail: java.lang.Exception: get dsKey is null at com.zd.archives.common.utils.ContextUtils.getDataSourceKey(ContextUtils.java:353) at com.zd.archives.sql.MultipleDataSource.determineCurrentLookupKey(MultipleDataSource.java:21) at org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource.determineTargetDataSource(AbstractRoutingDataSource.java:196) at org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource.getConnection(AbstractRoutingDataSource.java:164) at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:111) at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:77) at org.mybatis.spring.transaction.SpringManagedTransaction.openConnection(SpringManagedTransaction.java:82) at org.mybatis.spring.transaction.SpringManagedTransaction.getConnection(SpringManagedTransaction.java:68) at org.apache.ibatis.executor.BaseExecutor.getConnection(BaseExecutor.java:336) at org.apache.ibatis.executor.SimpleExecutor.prepareStatement(SimpleExecutor.java:84) at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:62) at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:324) at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:156) at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:109)抛出异常了
03-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值