首页 > 代码库 > mybatis3整合spring后如何使用自带连接池
mybatis3整合spring后如何使用自带连接池
mybatis3自带了数据库连接池。
单独使用mybatis3时只需要在mybatis的配置文件中定义datasouce的地方改变type这个属性为POOLED就可以了。
而在整合了spring之后,数据源不再是依靠mybatis的配置文件来定义了。而是通过SqlSessionFactoryBean中的dataSource属性
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> </bean>官方文档对于这个Bean是如此描述的:
SqlSessionFactory 有一个单独的必须属性,就是 JDBC 的 DataSource。这可以是任意 的 DataSource,其配置应该和其它 Spring 数据库连接是一样的。
一个通用的属性是 configLocation,它是用来指定 MyBatis 的 XML 配置文件路径的。 如果基本的 MyBatis 配置需要改变, 那么这就是一个需要它的地方。
通常这会是<settings> 或<typeAliases>的部分。
要注意这个配置文件不需要是一个完整的 MyBatis 配置。确切地说,任意环境,数据源 和 MyBatis 的事务管理器都会被忽略。
SqlSessionFactoryBean 会创建它自己的来定制 MyBatis 的 Environment 。
所以,我们现在无法再mybatis的配置文件中使用连接池了。
但是我们可以在spring上下文中定义的dataSource下手。也就是手动指定连接池:
<bean id="dataSource" class="org.apache.ibatis.datasource.pooled.PooledDataSource"> <property name="driver" value=http://www.mamicode.com/"${driver}" />>此时还要加上PropertyPlaceholderConfigurer来载入我们的配置文件<bean id="propertyConfigure" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:db.properties</value> </list> </property> </bean>
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。