整合思路
- SqlSessionFactroy对象应该放到spring容器中作为单例存在
- 传统dao的开发方式中,应该从spring 容器中获得sqlSession对象
- Mapper代理形式中,应该从spring 容器中直接获得mapper的代理对象
- 数据库的连接以及数据库连接池事物管理都交给spring 容器来管理
配置文件
SqlMapConfig.xml
- 数据库连接及连接池
- 事物管理
- SqlSessionFactory对象配置到spring容器中
- Mapper代理对象或者是dao是实现类配置到spring容器中
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 设置别名 -->
<typeAliases>
<!-- 指定扫描包 会把包内所有类都设置为别名 不区分大小写 -->
<package name="cn.tl.pojo"/>
</typeAliases>
<!-- 配置User.xml文件地址 -->
<mappers>
<mapper resource="cn/tl/pojo/User.xml"/>
</mappers>
</configuration>
applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd">
<!-- 加载配置文件 数据库配置文件 -->
<context:property-placeholder location="classpath:db.properties"/>
<!-- 数据库连接池
destroy-method:回调方法
maxActive:最大连接数
maxIdle:最大空闲-->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.