上一篇文章我单独使用了mybatis连接数据库做了测试,这篇文章我开始学习mybatis-spring的使用和配置。
首先我们同样要导入很多的jar包,最主要的就是mybatis-spring.jar了,其次就是spring框架的jar包
我是用的spring4.3.5,mybatis-spring1.3.1,dbcp1.4,pool1.6
本次我将整合所用到的jar包全部打包放在了
下载地址
提取码:86f0
大家可以参考借鉴。
上面一些mybatis的包在上一篇文章中已经导进去了连接也在上一篇文章里。把所有整合包导入后开始编写Mapper的实现类。
import org.apache.ibatis.session.SqlSession;
import org.mybatis.spring.support.SqlSessionDaoSupport;
import com.ssm.dao.CustomerMapper;
import com.ssm.doamin.Customer;
public class CustomerMapperIm extends SqlSessionDaoSupport implements CustomerMapper {
public void saveCustomer(Customer customer) {
// TODO Auto-generated method stub
SqlSession sqlSession = this.getSqlSession();
sqlSession.insert("saveCustomer",customer);
}
}
用SqlSessionDaoSupport的简便性拿到sqlsession,然后用sqlsession得到insert标签的方法。接口的话参见上一篇文章的接口类。在这个实现类里面我不需要再去提交事务有木有很方便。
接下来我开始编写一个applicationContext.xml文件,这一步是最关键的一步,在这个配置文件过程中我出了很多错,首先就是没有将dbcp和pool的jar包没有导入;多次测试发现找不到beans元素。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
</beans>
这是模板,在配置之前我需要写一个jdbc连接信息的properties文件
jdbc.url=jdbc:mysql://localhost:3306/user?characterEncoding=utf-8
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.user=root
jdbc.password=123123
这是我的数据库的信息,然后就是写applicationContext.xml的主要代码了
<!-- 读取jdbc连接池文件 -->
<context:property-placeholder location="classpath:jdbc.properties" />
<!-- 创建DataSource -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="url" value="${jdbc.url}"/>
<property name="driverClassName" value="${jdbc.driverClass}"/>
<property name="username" value="${jdbc.user}"/>
<property name="password" value="${jdbc.password}"/>
<property name="maxActive" value="10"/>
<property name="maxIdle" value="5"/>
</bean>
<!-- 创建SqlSession对象 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 关联连接池 -->
<property name="dataSource" ref="dataSource"/>
<!-- 加载sql映射文件 -->
<property name="mapperLocations" value="classpath:mapper/*.xml"/>
</bean>
<!-- 创建customerMapperIm的对象并且注入SqlSessionFactory -->
<bean id="customerMapper" class="com.ssm.dao.im.CustomerMapperIm">
<!-- 关联SqlSessionFactory -->
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
到这一步我的内容基本结束,下一步就是测试了。
import java.io.IOException;
import java.io.InputStream;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.ssm.dao.CustomerMapper;
import com.ssm.doamin.Customer;
public class MybatisSpringTest {
@Test
public void test() throws IOException{
//加载spring配置
ApplicationContext app = new ClassPathXmlApplicationContext("applicationContext.xml");
//获取对象
CustomerMapper customerMapper = (CustomerMapper) app.getBean("customerMapper");
//调用方法
Customer customer = new Customer();
customer.setName("校长");
customer.setGender("man");
customer.setTel("1031-8888888");
customer.setAddress("**********");
customerMapper.saveCustomer(customer);
}
}
测试的数据和上一篇文章是类似的。
总结一下发现整合后的mybatis-spring会比单独使用mybatis简单一点,将jdbc连接这一块简化了不少。