Spring整合mybatis

8 篇文章 0 订阅
3 篇文章 0 订阅

Spring整合mybatis

第一种:用sqlSessionTemplate

1.引入Spring配置文件beans.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
   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.xsd">

2.配置数据源替换mybaits的数据源

<!--配置数据源:数据源有非常多,可以使用第三方的,也可使使用Spring的-->
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
  <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
  <property name="url" value="jdbc:mysql://localhost:3306/mybatis?
useSSL=true&amp;useUnicode=true&amp;characterEncoding=utf8"/>
  <property name="username" value="root"/>
  <property name="password" value="123456"/>
</bean>

3.配置SqlSessionFactory,关联MyBatis

<!--配置SqlSessionFactory-->
<bean id="sqlSessionFactory"
class="org.mybatis.spring.SqlSessionFactoryBean">
  <property name="dataSource" ref="dataSource"/>
  <!--关联Mybatis 如果mybatis配置文件没东西,也可以省略-->
  <property name="configLocation" value="classpath:mybatis-config.xml"/>
  <property name="mapperLocations"
value="classpath:com/kuang/dao/*.xml"/>
</bean>

4.注册sqlSessionTemplate(sqlsession),关联sqlSessionFactory;

<!--注册sqlSessionTemplate , 关联sqlSessionFactory-->
<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
  <!--利用构造器注入-->
  <constructor-arg index="0" ref="sqlSessionFactory"/>
</bean>

5.增加Dao接口的实现类;私有化sqlSessionTemplate

public class UserDaoImpl implements UserMapper {
  //sqlSession不用我们自己创建了,Spring来管理
  private SqlSessionTemplate sqlSession;
  public void setSqlSession(SqlSessionTemplate sqlSession) {
    this.sqlSession = sqlSession;
 }
  public List<User> selectUser() {
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    return mapper.selectUser();
 }
 
}

6.注册userdaoImpl bean实现

<bean id="userDao" class="com.kuang.dao.UserDaoImpl">
  <property name="sqlSession" ref="sqlSession"/>
</bean>

7.测试

@Test
  public void test2(){
    ApplicationContext context = new
ClassPathXmlApplicationContext("beans.xml");
    UserMapper mapper = (UserMapper) context.getBean("userDao");
    List<User> user = mapper.selectUser();
    System.out.println(user);
 }

第二种:实现SqlSessionDaoSupport

dao继承Support类 , 直接利用 getSqlSession() 获得 , 然后直接注入SqlSessionFactory . 比起方式1 , 不需要管理SqlSessionTemplate , 而且对事务的支持更加友好 . 可跟踪源码查看

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EwTiIUjJ-1598110303923)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20200822232807110.png)]

测试:

1.将我们上面写的UserDaoImpl修改一下

public class UserDaoImpl extends SqlSessionDaoSupport implements
UserMapper {
  public List<User> selectUser() {
    UserMapper mapper = getSqlSession().getMapper(UserMapper.class);
    return mapper.selectUser();
 }
}

2.修改bean的配置

<bean id="userDao" class="com.kuang.dao.UserDaoImpl">
  <property name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean>

3.测试

@Test
public void test2(){
  ApplicationContext context = new
ClassPathXmlApplicationContext("beans.xml");
  UserMapper mapper = (UserMapper) context.getBean("userDao");
  List<User> user = mapper.selectUser();
  System.out.println(user);
}

总结 :

UserMapper) context.getBean(“userDao”);
  List user = mapper.selectUser();
  System.out.println(user);
}


## 总结 : 

整合到spring中以后可以完全不要mybatis的配置文件,除了这些方式可以实现整合之外,我们还可以使用注解来实现,这个等我们后面学SpringBoot的时候还会测试整合。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值