mybatis-spring整合经验

上一篇文章我单独使用了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连接这一块简化了不少。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值