Spring整合Mybatis和Junit

1 Spring整合Mybatis

大体需要做两件事,
第一件事是:Spring要管理MyBatis中的SqlSessionFactory
第二件事是:Spring要管理Mapper接口的扫描
具体该如何实现,具体的步骤为:

环境搭建

建表

CREATE TABLE account(
    id INT PRIMARY KEY AUTO_INCREMENT,
    NAME VARCHAR(35),
    money DOUBLE
);

INSERT INTO 
account VALUE 
(NULL,'张三',1000),
(NULL,'李四',2000),
(NULL,'王五',3000),
(NULL,'赵六',4000);

根据表创建模型类

package com.mySpring.pojo;

import java.io.Serializable;

/**
 * @author hyl
 * @version 1.0
 * @date 2023/1/7-20:44
 */

public class Account implements Serializable {

    private Integer id;
    private String name;
    private Double money;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Double getMoney() {
        return money;
    }

    public void setMoney(Double money) {
        this.money = money;
    }

    @Override
    public String toString() {
        return "Account{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", money=" + money +
                '}';
    }
}

创建Dao(Mapper)接口

package com.mySpring.dao;

import com.mySpring.pojo.Account;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;

import java.util.List;

/**
 * @author hyl
 * @version 1.0
 * @date 2023/1/7-20:45
 * 使用注解开发,不需要写对应的Mapper.xml
 */

public interface AccountDao {

    @Insert("insert into account(name,money)values(#{name},#{money})")
    void save(Account account);

    @Delete("delete from account where id = #{id} ")
    void delete(Integer id);

    @Update("update account set name = #{name} , money = #{money} where id = #{id} ")
    void update(Account account);

    @Select("select * from account")
    List<Account> findAll();

    @Select("select * from account where id = #{id} ")
    Account findById(Integer id);
}

创建Service接口

package com.mySpring.service;

import com.mySpring.pojo.Account;

import java.util.List;

/**
 * @author hyl
 * @version 1.0
 * @date 2023/1/7-20:46
 */

public interface AccountService {

    void save(Account account);

    void delete(Integer id);

    void update(Account account);

    List<Account> findAll();

    Account findById(Integer id);

}

创建Service接口实现类

package com.mySpring.service.impl;

import com.mySpring.dao.AccountDao;
import com.mySpring.pojo.Account;
import com.mySpring.service.AccountService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 * @author hyl
 * @version 1.0
 * @date 2023/1/7-20:47
 */

@Service
public class AccountServiceImpl implements AccountService {

    @Autowired
    private AccountDao accountDao;

    public void save(Account account) {
        accountDao.save(account);
    }

    public void update(Account account){
        accountDao.update(account);
    }

    public void delete(Integer id) {
        accountDao.delete(id);
    }

    public Account findById(Integer id) {
        return accountDao.findById(id);
    }

    public List<Account> findAll() {
        return accountDao.findAll();
    }
}

添加db.properties文件

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/table_04
username=root
password=123456

整合步骤

步骤1:项目中导入整合需要的jar包

<dependencies>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>5.2.10.RELEASE</version>
    </dependency>
    <!--德鲁伊数据库连接池-->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid</artifactId>
        <version>1.1.16</version>
    </dependency>
    <!--导入Mybatis-->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.6</version>
    </dependency>
    <!--连接数据库-->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.47</version>
    </dependency>
</dependencies>


<!--整合需要导入的-->
<dependency>
    <!--Spring操作数据库需要该jar包-->
    <groupId>org.springframework</groupId>
    <artifactId>spring-jdbc</artifactId>
    <version>5.2.10.RELEASE</version>
</dependency>
<dependency>
    <!--
		Spring与Mybatis整合的jar包
		这个jar包mybatis在前面,是Mybatis提供的
	-->
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>1.3.0</version>
</dependency>

步骤2:创建Spring的主配置类
替代applicationContext.xml文件

package com.mySpring.config;

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.context.annotation.PropertySource;


/**
 * @author hyl
 * @version 1.0
 * @date 2023/1/7-20:54
 */
//配置类注解
@Configuration
//包扫描,主要扫描的是项目中的AccountServiceImpl类
@ComponentScan({"com.mySpring"})
public class SpringConfig {
    
}

步骤3:创建数据源的配置类
在配置类中完成数据源的创建

package com.mySpring.config;

import com.alibaba.druid.pool.DruidDataSource;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;

import javax.sql.DataSource;

/**
 * @author hyl
 * @version 1.0
 * @date 2023/1/7-20:59
 * 数据源配置文件
 */

public class JdbcConfig {
//    从db.properties文件中获取值

    @Value("${driver}")
    private String driver;
    @Value("${url}")
    private String url;
    @Value("${username}")
    private String userName;
    @Value("${password}")
    private String password;
    @Bean
    public DataSource dataSource(){
        DruidDataSource ds = new DruidDataSource();
        ds.setDriverClassName(driver);
        ds.setUrl(url);
        ds.setUsername(userName);
        ds.setPassword(password);
        return ds;
    }
}

步骤4:主配置类中读properties并引入数据源配置类

@Configuration
@ComponentScan({"com.mySpring"})
//从类路径中读取properties文件
@PropertySource({"classpath:db.properties"})
//同时导入JdbcConfig配置类
@Import({JdbcConfig.class})
public class SpringConfig {
}

步骤5:创建Mybatis配置类并配置SqlSessionFactory

package com.mySpring.config;

import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.mapper.MapperScannerConfigurer;
import org.springframework.context.annotation.Bean;

import javax.sql.DataSource;

/**
 * @author hyl
 * @version 1.0
 * @date 2023/1/7-21:07
 * Mybatis配置文件(等同于mybatis-config.xml配置文件)
 */

public class MybatisConfig {
    /**
     * 定义bean,SqlSessionFactoryBean,用于产生SqlSessionFactory对象
     * =====================================================
     * dataSource从JdbcConfig中获取,替代配置文件中的
     *<dataSource type="POOLED">
     *      <property name="driver" value="${driver}"/>
     *      <property name="url" value="${url}"/>
     *      <property name="username" value="${username}"/>
     *      <property name="password" value="${password}"/>
     *</dataSource>
     *
     *======================================================
     *
     * setTypeAliasesPackage("com.mySpring.pojo")替代起别名
     *<typeAliases>
     *   <package name="com.mySpring.pojo"/>
     *</typeAliases>
     *
     * =====================================================
     * @param dataSource 获取的DataSource在ioc容器中已经注入,会自动装填
     * @return 返回一个sqlSession对象
     */
    @Bean
    public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource){
        SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean();
        //设置模型类的别名扫描
        ssfb.setTypeAliasesPackage("com.mySpring.pojo");
        //设置数据源
        ssfb.setDataSource(dataSource);
        return ssfb;
    }

    /**
     * 定义bean,返回MapperScannerConfigurer对象,替代
     * <mappers>
     *      <package name="com.mySpring.dao"/>
     *<mappers/>
     * @return
     */
    @Bean
    public MapperScannerConfigurer mapperScannerConfigurer(){
        MapperScannerConfigurer msc = new MapperScannerConfigurer();
        msc.setBasePackage("com.mySpring.dao");
        return msc;
    }
}

说明:

  • 使用SqlSessionFactoryBean封装SqlSessionFactory需要的环境信息

在这里插入图片描述

  • SqlSessionFactoryBean是前面我们讲解FactoryBean的一个子类,在该类中将SqlSessionFactory的创建进行了封装,简化对象的创建,我们只需要将其需要的内容设置即可。
  • 方法中有一个参数为dataSource,当前Spring容器中已经创建了Druid数据源,类型刚好是DataSource类型,此时在初始化SqlSessionFactoryBean这个对象的时候,发现需要使用DataSource对象,而容器中刚好有这么一个对象,就自动加载了DruidDataSource对象。
  • 使用MapperScannerConfigurer加载Dao接口,创建代理对象保存到IOC容器中

在这里插入图片描述

  • 这个MapperScannerConfigurer对象也是MyBatis提供的专用于整合的jar包中的类,用来处理原始配置文件中的mappers相关配置,加载数据层的Mapper接口类
  • MapperScannerConfigurer有一个核心属性basePackage,就是用来设置所扫描的包路径

步骤6:主配置类中引入Mybatis配置类

@Configuration
@ComponentScan({"com.mySpring"})
@PropertySource("classpath:db.properties")
导入MybatisConfig配置类
@Import({JdbcConfig.class,MybatisConfig.class})
public class SpringConfig {
}

步骤7:编写运行类

package com.mySpring.test;

import com.mySpring.config.SpringConfig;
import com.mySpring.pojo.Account;
import com.mySpring.service.AccountService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;

/**
 * @author hyl
 * @version 1.0
 * @date 2023/1/7-21:24
 */

public class App2 {
    public static void main(String[] args) {
        ApplicationContext ctx = new AnnotationConfigApplicationContext(SpringConfig.class);

        AccountService accountService = ctx.getBean(AccountService.class);

        Account ac = accountService.findById(2);
        System.out.println(ac);
    }
}

在这里插入图片描述

使用的注解详解

@Component注解,衍生出了其他三个注解@Controller、@Service、@Repository
这三个注解和@Component注解的作用是一样的,为什么要衍生出这三个呢?
方便我们后期在编写类的时候能很好的区分出这个类是属于表现层、业务层还是数据层的类。

名称@Component/@Controller/@Service/@Repository
类型类注解
位置类定义上方
作用设置该类为spring管理的bean
属性value(默认):定义bean的id
名称@Configuration
类型类注解
位置类定义上方
作用设置该类为spring配置类
属性value(默认):定义bean的id
名称@ComponentScan
类型类注解
位置类定义上方
作用设置spring配置类扫描路径,用于加载使用注解格式定义的bean
属性value(默认):扫描路径,此路径可以逐层向下扫描
名称@Value
类型属性注解 或 方法注解(了解)
位置属性定义上方 或 标准set方法上方 或 类set方法上方
作用为 基本数据类型 或 字符串类型 属性设置值
属性value(默认):要注入的属性值
名称@PropertySource
类型类注解
位置类定义上方
作用加载properties文件中的属性值
属性value(默认):设置加载的properties文件对应的文件名或文件名组成的数组
名称@Autowired
类型属性注解 或 方法注解(了解) 或 方法形参注解(了解)
位置属性定义上方 或 标准set方法上方 或 类set方法上方 或 方法形参前面
作用为引用类型属性设置值
属性required:true/false,定义该属性是否允许为null
名称@Qualifier
类型属性注解 或 方法注解(了解)
位置属性定义上方 或 标准set方法上方 或 类set方法上方
作用为引用类型属性指定注入的beanId
属性value(默认):设置注入的beanId
名称@Bean
类型方法注解
位置方法定义上方
作用设置该方法的返回值作为spring管理的bean
属性value(默认):定义bean的id
名称@Import
类型类注解
位置类定义上方
作用导入配置类
属性value(默认):定义导入的配置类类名,
当配置类有多个时使用数组格式一次性导入多个配置类

2 Spring整合Junit

整合Junit与整合Druid和MyBatis差异比较大,为什么呢?Junit是一个搞单元测试用的工具,它不是我们程序的主体,也不会参加最终程序的运行,从作用上来说就和之前的东西不一样,它不是做功能的,看做是一个辅助工具就可以了。

整合Junit步骤

步骤1:引入依赖
在原有的pom.xml的基础上(借助mybatis去测试)

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.12</version>
    <scope>test</scope>
</dependency>

<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-test</artifactId>
    <version>5.2.10.RELEASE</version>
</dependency>

步骤2:编写测试类

import com.mySpring.config.SpringConfig;
import com.mySpring.service.AccountService;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

/**
 * @author hyl
 * @version 1.0
 * @date 2023/1/7-22:18
 */

//设置类运行器
@RunWith(SpringJUnit4ClassRunner.class)
//设置Spring环境对应的配置类
@ContextConfiguration(classes = {SpringConfig.class}) //加载配置类
//@ContextConfiguration(locations={"classpath:applicationContext.xml"})//加载配置文件
public class AccountServiceTest {
    //支持自动装配注入bean
    @Autowired
    private AccountService accountService;
    @Test
    public void testFindById(){
        System.out.println(accountService.findById(1));

    }
    @Test
    public void testFindAll(){
        System.out.println(accountService.findAll());
    }
}

在这里插入图片描述

注意:

  • 单元测试,如果测试的是注解配置类,则使用@ContextConfiguration(classes = 配置类.class)
  • 单元测试,如果测试的是配置文件,则使用@ContextConfiguration(locations={配置文件名,...})
  • Junit运行后是基于Spring环境运行的,所以Spring提供了一个专用的类运行器,这个务必要设置,这个类运行器就在Spring的测试专用包中提供的,导入的坐标就是这个东西SpringJUnit4ClassRunner
  • 上面两个配置都是固定格式,当需要测试哪个bean时,使用自动装配加载对应的对象,下面的工作就和以前做Junit单元测试完全一样了

使用的注解详解

名称@RunWith
类型测试类注解
位置测试类定义上方
作用设置JUnit运行器
属性value(默认):运行所使用的运行期
名称@ContextConfiguration
类型测试类注解
位置测试类定义上方
作用设置JUnit加载的Spring核心配置
属性classes:核心配置类,可以使用数组的格式设定加载多个配置类
locations:配置文件,可以使用数组的格式设定加载多个配置文件名称
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Spring框架提供了非常便捷的整合MyBatisJUnit并进行事务管理的方式。下面是一个简单的示例: 首先,我们需要在Spring配置文件中声明MyBatis的SqlSessionFactory和MapperScannerConfigurer: ``` <!-- 数据源配置 --> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="${jdbc.driverClassName}"/> <property name="url" value="${jdbc.url}"/> <property name="username" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> </bean> <!-- MyBatis SqlSessionFactory 配置 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="mapperLocations" value="classpath*:com/example/mapper/*.xml"/> </bean> <!-- MapperScannerConfigurer 配置 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.example.mapper"/> </bean> ``` 其中,dataSource是数据源配置,sqlSessionFactory是MyBatis的SqlSessionFactory配置,mapperLocations指定了MyBatis的Mapper映射文件所在的路径,MapperScannerConfigurer则是MyBatis的Mapper接口扫描配置。 接下来,我们需要在Spring配置文件中配置事务管理器和事务通知: ``` <!-- 事务管理器配置 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> <!-- 事务通知配置 --> <tx:advice id="txAdvice" transaction-manager="transactionManager"> <tx:attributes> <tx:method name="*"/> </tx:attributes> </tx:advice> <aop:config> <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.example.service.*.*(..))"/> </aop:config> ``` 其中,transactionManager是事务管理器的配置,txAdvice是事务通知的配置,用于定义事务的传播行为和隔离级别,aop:advisor则是将事务通知织入Service层的切点中。 最后,我们需要在JUnit测试类中注入Mapper接口和Service实例,并在测试方法中进行事务操作: ``` @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = {"classpath:spring-config.xml"}) @Transactional public class UserServiceTest { @Autowired private UserMapper userMapper; @Autowired private UserService userService; @Test public void testAddUser() throws Exception { User user = new User(); user.setName("test"); user.setAge(18); userService.addUser(user); User result = userMapper.getUserById(user.getId()); assertNotNull(result); assertEquals(user.getName(), result.getName()); assertEquals(user.getAge(), result.getAge()); } } ``` 其中,@RunWith(SpringJUnit4ClassRunner.class)和@ContextConfiguration(locations = {"classpath:spring-config.xml"})用于加载Spring配置文件,@Transactional用于声明事务,@Autowired用于注入Mapper接口和Service实例,testAddUser方法中则是进行事务操作并进行断言。 通过以上配置和示例,我们就可以完整地实现Spring整合MyBatisJUnit并进行事务管理了。 ### 回答2: Spring整合MyBatisJUnit及事务管理是一种常见的开发方式,可以使开发人员更方便地进行单元测试和事务管理。 首先,Spring整合MyBatis可以通过配置来实现。在Spring的配置文件中,我们可以定义MyBatis的数据源和SqlSessionFactory,并将其注入到Spring容器中。同时,我们还可以通过配置MapperScannerConfigurer来扫描MyBatis的mapper接口,并自动将其注册到Spring容器中。这样,我们就可以在Spring中使用MyBatis的mapper接口来进行持久化操作。 接下来,使用JUnit进行单元测试。在Spring中,我们可以使用Spring Test模块提供的JUnit运行器来执行我们的单元测试。通过配置@ContextConfiguration注解,我们可以指定需要加载的Spring配置文件,并使用@Autowired注解来自动注入我们需要测试的对象。此外,我们还可以使用@TransactionConfiguration注解来配置事务管理器的一些属性,以保证在测试期间的事务控制。 最后,事务管理是一个非常重要的功能。在Spring中,我们可以通过配置@EnableTransactionManagement注解来启用事务管理功能。通过在方法上添加@Transactional注解,我们可以指定哪些方法需要进行事务管理。在事务控制的过程中,Spring会根据配置来进行事务的提交或回滚操作,以保证数据的一致性和完整性。 总而言之,Spring整合MyBatisJUnit及事务管理是一种灵活而方便的开发方式,可以帮助开发人员更好地进行单元测试和事务管理。通过合理配置,我们可以充分发挥Spring框架的功能,提高开发效率和代码质量。 ### 回答3: Spring整合MyBatisJUnit及事务管理是常见的企业级Java应用开发方案之一。下面我将用300字回答这个问题。 首先,Spring整合MyBatisJUnit可以方便地进行持久化数据层和业务逻辑层的单元测试。通过使用Spring的测试框架和JUnit,开发人员可以轻松地编写和运行单元测试,以有效地验证代码的正确性和稳定性。通过整合MyBatis,可以使用MyBatis的Mapper接口来访问数据库,并结合Spring的依赖注入功能,将MyBatis的Mapper接口注入到测试类中,方便进行数据库操作的模拟或真实测试。 其次,Spring整合MyBatis还可以简化事务管理。Spring提供了一个统一的事务管理器,可以方便地管理数据库操作的事务,确保数据的完整性和一致性。通过在Spring配置文件中配置事务管理器和事务属性,可以将事务的控制从业务逻辑中解耦出来,使得代码更加清晰和可维护。在JUnit测试中,也可以使用Spring的事务管理功能,方便地回滚数据库操作,保持测试环境的干净和一致性。 最后,Spring整合MyBatisJUnit还可以提高代码的可测试性和可扩展性。通过使用依赖注入和面向接口编程的思想,可以实现代码的解耦和模块化,使得代码更容易被维护和扩展。同时,使用JUnit进行单元测试可以及早地发现和修复代码中的问题,提高代码的质量和稳定性。 综上所述,Spring整合MyBatisJUnit及事务管理是一种强大且灵活的应用开发方案,可以帮助开发人员更加高效和方便地进行单元测试和事务管理,提高代码的质量和可维护性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值