背景:手上有一个J2EE项目,数据库存储使用的Spring JdbcTemplate写的存储操作。现在将Mybatis加入,不想重写以前已经存在的JdbcTemplate操作语句,使项目同时支持Mybatis跟JdbcTemplate。
具体操作:
Spring JdbcTemplate使用DataSource,DataSource可以作为参数传入JdbcTemplate。
JdbcTemplatetemplate=newJdbcTemplate(dataSource);
从Mybatis获取DataSource时:
DataSourcedataSource=MybatisDb.getSqlSessionFactory().getConfiguration().getEnvironment().getDataSource();
从SqlSessionFactory()中获取DataSource,不可以从SqlSession中获取,SqlSession是每次执行CRUD获取的,用完就需要关闭。
Mybatis中数据库配置为pooled模式时,获得的DataSource可以转型为PooledDataSource 类型。
PooledDataSource pooledDataSource = (PooledDataSource) MybatisDb.getSqlSessionFactory().getConfiguration().getEnvironment().getDataSource();
这时PooledDataSource 可以获取数据库连接池的详情,例如数据闲置多少等。
pooledDataSource.getPoolMaximumIdleConnections()
备注:
在具体操作中遇到一个问题,我把SqlSession作为一个单例,在操作一段时间后,会发现不能对数据库进行操作。SqlSession的使用方法是:每次CRUD 从SqlSessionFactory产生一个新的,使用完毕close。 SqlSessionFactory是对线程池的管理,每次操作数据库,从SqlSessionFactory产生一个新的。