SpringBoot 整合 Mybatis 进行CRUD测试开发
今天来和大家分享下 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>
本文及代码参考自 tycoding,感谢分享。
SpringBoot 整合 Mybatis 进行CRUD测试开发的更多相关文章
- 学习springboot整合mybatis并编写测试类
报名立减200元.暑假直降6888. 邀请链接:http://www.jnshu.com/login/1/20535344 邀请码:20535344 遇到的问题: 1.原因是在启动类上只有一个@Map ...
- 【java框架】SpringBoot(7) -- SpringBoot整合MyBatis
1.整合MyBatis操作 前面一篇提到了SpringBoot整合基础的数据源JDBC.Druid操作,实际项目中更常用的还是MyBatis框架,而SpringBoot整合MyBatis进行CRUD也 ...
- springboot整合mybatis(SSM开发环境搭建)
0.项目结构: ---------------------方法一:使用mybatis官方提供的Spring Boot整合包实现--------------------- 1.application.p ...
- Java开发学习(三十九)----SpringBoot整合mybatis
一.回顾Spring整合Mybatis Spring 整合 Mybatis 需要定义很多配置类 SpringConfig 配置类 导入 JdbcConfig 配置类 导入 MybatisConfig ...
- SpringBoot整合Mybatis【非注解版】
接上文:SpringBoot整合Mybatis[注解版] 一.项目创建 新建一个工程 选择Spring Initializr,配置JDK版本 输入项目名 选择构建web项目所需的state ...
- SpringBoot系列七:SpringBoot 整合 MyBatis(配置 druid 数据源、配置 MyBatis、事务控制、druid 监控)
1.概念:SpringBoot 整合 MyBatis 2.背景 SpringBoot 得到最终效果是一个简化到极致的 WEB 开发,但是只要牵扯到 WEB 开发,就绝对不可能缺少数据层操作,所有的开发 ...
- SpringBoot整合Mybatis完整详细版
记得刚接触SpringBoot时,大吃一惊,世界上居然还有这么省事的框架,立马感叹:SpringBoot是世界上最好的框架.哈哈! 当初跟着教程练习搭建了一个框架,传送门:spring boot + ...
- 三、SpringBoot 整合mybatis 多数据源以及分库分表
前言 说实话,这章本来不打算讲的,因为配置多数据源的网上有很多类似的教程.但是最近因为项目要用到分库分表,所以让我研究一下看怎么实现.我想着上一篇博客讲了多环境的配置,不同的环境调用不同的数据库,那接 ...
- 001 SringBoot基础知识及SpringBoot整合Mybatis
1.原有Spring优缺点分析 (1)优点 Spring是Java企业版(Java Enterprise Edition,JEE,也称J2EE)的轻量级代替品.无需开发重量级的Enterprise J ...
随机推荐
- [csdn markdown]使用摘记一源码高亮及图片上传和链接
本文主要内容是体验csdn markdown的代码块高亮显示和图片链接及上传. 图片上传 上边这是标题行.仅仅须要使用一个#就能够表示.几个表示是几级标题 图片上传 本地图片上传控件 本地图片上传方式 ...
- HDU1698 Just a Hook 【线段树】+【成段更新】+【lazy标记】
Just a Hook Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- Windows移动开发(五)——初始XAML
关于详细的基本功就先说这么多.后面遇到再补充说明,前面说的都是一些代码和原理方面的东西.接下来说的会有界面和代码结合,会有成就感,由于能真正的做出东西来了. Windows移动开发包含Windows ...
- Corona 不同设备分辨率适应
移动平台下,不同设备的宽高比不同,那么必然存在与游戏设计时的宽高比不一致的情况,Corona的解决方案是定义了一个虚拟的屏幕高宽,比如1024*768,然后在不同设备上通过定义的适应模式去调整这个虚拟 ...
- 使用Linq 查询数据 构建对象 select new{}
linq 查询数据 /// <summary> /// 汽车品牌及车型 /// </summary> /// <returns></returns> p ...
- HDU 3572 Task Schedule(ISAP模板&&最大流问题)
题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=3572 题意:m台机器.须要做n个任务. 第i个任务.你须要使用机器Pi天,且这个任务要在[Si , ...
- arm下用shell控制gpio
创建脚本gpio.sh #!/bin/sh PIN=$ VALUE=$ if test -d /sys/class/gpio/gpio$PIN/ then echo $VALUE > /sys/ ...
- arm linux串口蓝牙工具移植及使用【转】
本文转载自:http://blog.csdn.net/hclydao/article/details/51451725 p6212中串口蓝牙在linux下的使用记录 一.linux蓝牙工具移植 主要使 ...
- Mongo 中间件 pre find 修改query
需求:在所有find查询的时候,默认添加查询参数 name:bennman //创建一个query中间件 myMid.js module.exports = function(schema){ //这 ...
- hdoj--5625--Clarke and chemistry(枚举)
Clarke and chemistry Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Oth ...