今天来和大家分享下 Spring Boot 整合 MyBatis 的 CRUD 测试方法开发。因为 MyBaits 有两种开发形式,一种基于注解,一种基于 xml 。

SpringBoot配置文件也有*.properties*.yaml两种形式。下面,我也会使用不同的开发形式进行分享。

环境准备

引入依赖

        <!--Mybatis依赖-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.0.1</version>
        </dependency>
        <!--Druid数据库连接池-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.10</version>
        </dependency>
        <!--MySQL-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

配置参数(application.properties)

# dataSource 配置
spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.url=jdbc:mysql://127.0.0.1:3306/testdb?serverTimezone=Asia/Shanghai&characterEncoding=utf-8
spring.datasource.druid.username=root
spring.datasource.druid.password=root

# 开启mybatis驼峰命名
mybatis.configuration.map-underscore-to-camel-case=true

初始化数据库

-- CREATE DATABASE testdb;

use testdb;
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user`  (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `username` varchar(255)  COMMENT '用户名',
  `password` varchar(255) COMMENT '密码',
  `create_time` datetime  COMMENT '创建日期',
  PRIMARY KEY (`id`)
) ENGINE = InnoDB CHARACTER SET = utf8 ;

实体类

package com.github.smallminmin.springboot.domain;

import lombok.Data;

import java.io.Serializable;
import java.util.Date;

@Data
public class User implements Serializable {
    private Long id;
    private String username;
    private String password;
    private Date createTime;
}

注解版实现

注解版实现替代 xml形式写 sql 语句,只需在 mapper 文件各个方法的上面加入相应的注解即可,例如:@Select@Insert@Delete@Update等。

创建 mapper

@Mapper
@Repository
public interface UserDao {
    /**
     * 插入数据
     */
    @Insert("insert into user(username,password,create_time) values(#{username},#{password},#{createTime})")
    void save(User user);

    /**
     * 根据用户id删除数据
     */
    @Delete("delete from user where id = #{id}")
    void deleteById(long id);

    /**
     * 更改用户数据
     */
    @Update("update user set username=#{username},password=#{password} where id=#{id}")
    void update(User user);

    /**
     * 查询所有的用户
     */
    @Select("select * from user")
    @Results({
            @Result(property = "createTime", column = "create_time")
    })
    List<User> findAll();

    /**
     * 根据用户id查询数据
     */
    @Select("select * from user where id = #{id}")
    @Results({
            @Result(property = "createTime", column = "create_time")
    })
    User findById(long id);
}

由于使用MyBatis的接口代理开发模式,且接口和 xml 需要名称相同。那么在 SpringBoot整合 MyBaits 中也要有对应的配置:

  • 方式一:在每个 mapper 类上添加@Mapper 注解
  • 方式二:在Application.java的SpringBoot启动类上,添加@MapperScan("com.github.smallminmin.springboot.dao")

@Result注解用于修饰返回结果集,若实体类和数据库表字段不一致也可用其修饰

测试类

package com.github.smallminmin.springboot.dao;

import com.github.smallminmin.springboot.domain.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import java.util.Date;
import java.util.List;
import java.util.Random;

@SpringBootTest
@RunWith(SpringRunner.class)
public class UserDaoTest {

    private Logger logger = LoggerFactory.getLogger(this.getClass());

    @Autowired
    private UserDao userDao;

    Random random = new Random();
    User user = new User();

    @Test
    public void save() {
        for (int i = 0; i < 10; i++) {
            int rand = random.nextInt(100);
            user.setUsername("xxx" + rand);
            user.setPassword("ddd" + rand);
            user.setCreateTime(new Date());
            userDao.save(user);
        }
    }

    @Test
    public void deleteById() {
        userDao.deleteById(20l);
        findAll();
    }

    @Test
    public void update() {
        int rand = random.nextInt(100);
        user.setUsername("update" + rand);
        user.setPassword("pwd" + rand);
        user.setId(19l);
        userDao.update(user);
        findAll();
    }

    @Test
    public void findAll() {
        List<User> all = userDao.findAll();
        for (User user1 : all) {
            logger.info("user={}", user1);
        }
    }

    @Test
    public void findById() {
        User byId = userDao.findById(20l);
        logger.info("user={}", byId);
    }

}

xml 实现

准备配置文件(application.yml)

# dataSource
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/testdb?serverTimezone=Asia/Shanghai&characterEncoding=utf-8
    username: root
    password: root
# mybatis
mybatis:
  mapper-locations: classpath:mapper/**/*.xml
  type-aliases-package: com.github.smallminmin.springboot.domain
  configuration:
    # 使用jdbc的getGeneratedKeys 可以获取数据库自增主键值
    use-generated-keys: true
    # 开启驼峰命名转换,如:Table(create_time) -> Entity(createTime)。不需要我们关心怎么进行字段匹配,mybatis会自动识别`大写字母与下划线`
    map-underscore-to-camel-case: true

创建mapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.github.smallminmin.springboot.dao.UserDao">

    <select id="findAll" resultType="com.github.smallminmin.springboot.domain.User">
        select * from user
    </select>

    <select id="findById" resultType="com.github.smallminmin.springboot.domain.User">
        select * from user where id = #{id}
    </select>

    <insert id="save" parameterType="com.github.smallminmin.springboot.domain.User">
        insert into user(username,password,create_time) values(#{username},#{password},#{createTime})
    </insert>

    <update id="update" parameterType="com.github.smallminmin.springboot.domain.User">
        update user set username=#{username},password=#{password} where id=#{id}
    </update>

    <delete id="deleteById" parameterType="long">
        delete from user where id=#{id}
    </delete>

</mapper>

Github代码示例

本文及代码参考自 tycoding,感谢分享。

SpringBoot 整合 Mybatis 进行CRUD测试开发的更多相关文章

  1. 学习springboot整合mybatis并编写测试类

    报名立减200元.暑假直降6888. 邀请链接:http://www.jnshu.com/login/1/20535344 邀请码:20535344 遇到的问题: 1.原因是在启动类上只有一个@Map ...

  2. 【java框架】SpringBoot(7) -- SpringBoot整合MyBatis

    1.整合MyBatis操作 前面一篇提到了SpringBoot整合基础的数据源JDBC.Druid操作,实际项目中更常用的还是MyBatis框架,而SpringBoot整合MyBatis进行CRUD也 ...

  3. springboot整合mybatis(SSM开发环境搭建)

    0.项目结构: ---------------------方法一:使用mybatis官方提供的Spring Boot整合包实现--------------------- 1.application.p ...

  4. Java开发学习(三十九)----SpringBoot整合mybatis

    一.回顾Spring整合Mybatis Spring 整合 Mybatis 需要定义很多配置类 SpringConfig 配置类 导入 JdbcConfig 配置类 导入 MybatisConfig ...

  5. SpringBoot整合Mybatis【非注解版】

    接上文:SpringBoot整合Mybatis[注解版] 一.项目创建 新建一个工程 ​ 选择Spring Initializr,配置JDK版本 ​ 输入项目名 ​ 选择构建web项目所需的state ...

  6. SpringBoot系列七:SpringBoot 整合 MyBatis(配置 druid 数据源、配置 MyBatis、事务控制、druid 监控)

    1.概念:SpringBoot 整合 MyBatis 2.背景 SpringBoot 得到最终效果是一个简化到极致的 WEB 开发,但是只要牵扯到 WEB 开发,就绝对不可能缺少数据层操作,所有的开发 ...

  7. SpringBoot整合Mybatis完整详细版

    记得刚接触SpringBoot时,大吃一惊,世界上居然还有这么省事的框架,立马感叹:SpringBoot是世界上最好的框架.哈哈! 当初跟着教程练习搭建了一个框架,传送门:spring boot + ...

  8. 三、SpringBoot 整合mybatis 多数据源以及分库分表

    前言 说实话,这章本来不打算讲的,因为配置多数据源的网上有很多类似的教程.但是最近因为项目要用到分库分表,所以让我研究一下看怎么实现.我想着上一篇博客讲了多环境的配置,不同的环境调用不同的数据库,那接 ...

  9. 001 SringBoot基础知识及SpringBoot整合Mybatis

    1.原有Spring优缺点分析 (1)优点 Spring是Java企业版(Java Enterprise Edition,JEE,也称J2EE)的轻量级代替品.无需开发重量级的Enterprise J ...

随机推荐

  1. 南昌互联网行业协会筹办者祝真和华罡团队-2014年12月江西IDC排行榜

     他出自军营,拥有一身正气. 他在南昌创业,立意卓越. 从站点開始.到微营销.到线上教育,全面开花. 他在朋友圈看到不对的内容,就会即时批评. 他对朋友,又是很的和蔼可亲. 他就是南昌华罡网络创办 ...

  2. Java集合类汇总记录--guava篇

    BiMap HashBiMap<K,V> 实现了两份哈希表数据结构(本类独立实现).分别负责两个方向的映射. EnumBiMap<K,V> 两个EnumMap对象分别负责两个方 ...

  3. Codeforces Round #332 (Div. 2)A. Patrick and Shopping 水

    A. Patrick and Shopping   Today Patrick waits for a visit from his friend Spongebob. To prepare for ...

  4. Spring+Mybatis之注册功能demo

    这次先注册功能的是基于登录之后,所以很多配置,实体类等就不再赘述了. 首先也不是直接在地址栏输入一个网页就可以到注册页面的.而是需要通过后台发送一个请求从而跳转到注册页面 先写注册页面,body部分 ...

  5. LA6878

    区间dp dp[i][j]存i->j区间的所有取值 然后枚举分割点,枚举两个存的值,分别运算存储. 看见这种不确定分割顺序,两个区间合并的情况,就要用区间dp. #include<bits ...

  6. UIDynamicBehavior的简单使用:接球小游戏

    一.概念扩充: 1.在开发中,我们可以使用UIKit中提供的仿真行为,实现与现实生活中类似的物理仿真动画,UIKit动力学最大的特点是将现实世界动力驱动的动画引入了UIKit,比如重力,铰链连接,碰撞 ...

  7. XML案例(使用JAXP进行SAX解析)

    1.Book.java package cn.itcast.sax; public class Book { private String name; private String author; p ...

  8. bzoj 1503郁闷的出纳员(splay)

    1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 11759  Solved: 4163[Submit][Stat ...

  9. javaweb 课程设计编码和设计文档

    企业办公软件设计文档 1引言 1.1编写目的 OA办公自动化系统详细设计是设计的第三个阶段,这个阶段的主要任务是在OA办公自动化系统概要设计书基础上,对概要设计中产生的功能模块进行过程描述,设计功能模 ...

  10. xml转换成数组array

    直接上代码,成功转换 if($data){ //返回来的是xml格式需要转换成数组再提取值,用来做更新 $startnum = strpos($data,"<xml>" ...