【 SpringBoot单元测试 和 Mybatis 增,删,改 操作 】

news/2024/4/25 21:45:30/文章来源:https://blog.csdn.net/qq_64317046/article/details/130318287

文章目录

  • 一、Spring-Boot单元测试(了解)
    • 1.1 概念
    • 1.2 单元测试引用
    • 1.3 单元测试的实现
    • 1.4 简单的断言说明
    • 1.5 单元测试优点
  • 二、Mybatis 增,删,改 操作
    • 2.1 增加⽤户操作
    • 2.2 修改⽤户操作
    • 2.3 删除⽤户操作

一、Spring-Boot单元测试(了解)

1.1 概念

  1. 单元测试(unit testing),是指对软件中的最小可测试单元进行检查和验证。在Java中单元测试的最小单元是类

  2. 单元测试是开发者编写的一小段代码,用于检验被测代码的一个很小的、很明确的功能是否正确。执行单元测试,就是为了证明这段代码的行为和我们期望是否一致

1.2 单元测试引用

使用单元测试需要引入依赖,一般框架都已经自动注入了该依赖 !!

在这里插入图片描述

原理:

通过spring initialize创建的Spring Boot项目会在Maven中自动携带很多starter依赖,而其中就存在该测试依赖 !

在这里插入图片描述

1.3 单元测试的实现

  1. 生成单元测试的类
    在接口层中,右击鼠标点击Generate选择Test
    在这里插入图片描述

在这里插入图片描述

以下就生成了该接口的测试类,并有接口中声明方法对应的测试方法

在这里插入图片描述

  1. 配置单元测试的类
    添加 @SpringBootTest 注解,再添加业务代码
//1、必须添加以下注解:该注解表示,以下测试单元代码 是在 Spring 中运行的
@SpringBootTest
@Slf4j
class UserInfoMapperTest {//2、添加需要测试单个功能的代码@Resourceprivate UserInfoMapper userInfoMapper;@Testvoid getUserById() {UserInfo userInfo = userInfoMapper.getUserById(1);// System.out.println(userInfo);  此时只是打印结果,无论代码是否错误,单元测试都会通过//以下 使用断言 来检测单元测试结果 ! 我们可以 设置 id 为确实存在于数据库的,如果测试单元不通过就说明上述功能代码存在问题//通过功能代码查询到的对象结果 和 Null 进行对比(还有很多其他方法,结果和True对比等),如果不为空的话,单元测试就会成功Assertions.assertNotNull(userInfo);}

注意:

  1. 必须添加 @SpringBootTest 注解:该注解表示,以下测试单元代码 是在 SpringBoot中运行的

  2. 如果使用的是科学版IDEA,在Test测试代码中使用 @Autowired 注入注解会报错因为:@Mapper来自mybatis框架,而@Autowired 来自 spring,没有兼容性。而使用JDK官方的@Resource可以

1.4 简单的断言说明

在这里插入图片描述

使用方法如上述代码 !

1.5 单元测试优点

在这里插入图片描述

上述内容只是大概认识了解下单元测试,详细内容参考这里 !


二、Mybatis 增,删,改 操作

在前面我们已经创建了第一个 mybatis 项目,并完成了简单的查询操作!后续执行的增删改操作大体步骤相似,需要更改 xml 文件中部分标签,下面我们就来学习 !

下面示例为了方便,我们就不依次完成各层书写,只需要把接口层补充完整,并完成 xml 文件的代码,再通过单元测试来验证结果 !!

注意:如果你不想破坏数据库的数据,可以使用 注解 @Transaction 进行事务回滚

2.1 增加⽤户操作

mapper 接口层实现:

package com.example.demo.mapper;import com.example.demo.model.UserInfo;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;@Mapper
public interface UserInfoMapper {public int addUser(UserInfo userInfo);}

相应的 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">
<!--namespace 需要实现的接口的具体包名加接口名-->
<mapper namespace="com.example.demo.mapper.UserInfoMapper"><!-- 添加用户 此时#{}获取的参数,就是用户表中对应的属性--><insert id="addUser">insert into userinfo(username, password, photo)values (#{username}, #{password}, #{photo})</insert></mapper>

生成对应的单元测试代码:

    @Testvoid addUser() {UserInfo userInfo = new UserInfo();userInfo.setUsername("guishao");userInfo.setPassword("526398");userInfo.setPhoto("default");int result = userInfoMapper.addUser(userInfo);Assertions.assertEquals(1,result);}

运行该测试方法,并观察结果:

在这里插入图片描述

查看数据库数据:

在这里插入图片描述

显而易见,我们成功的添加了一个用户 !!


特殊的添加:返回⾃增 id

xml 文件中的代码实现如下:

<!-- 添加用户 返回受影响的行数和自增id ! useGeneratedKeys:表示是否开起id自增
keyProperty:将自增的id值赋值给实体对象的哪个属性 keyColumn:将自增的id赋值给数据库中的哪一个字段-->
<insert id="addUser1" useGeneratedKeys="true" keyProperty="id" keyColumn="id">insert into userinfo(username, password, photo)values (#{username}, #{password}, #{photo})
</insert>

标签说明:

  1. useGeneratedKeys:这会令 MyBatis 使⽤ JDBC 的 getGeneratedKeys ⽅法来取出由数据
    库内部⽣成的主键(⽐如:像 MySQL 和 SQL Server 这样的关系型数据库管理系统的⾃动递
    增字段),默认值:false
  2. keyColumn:设置⽣成键值在表中的列名,在某些数据库(像 PostgreSQL)中,当主键列
    不是表中的第⼀列的时候,是必须设置的。如果⽣成列不⽌⼀个,可以⽤逗号分隔多个属性
    名称
  3. keyProperty:指定能够唯⼀识别对象的属性,MyBatis 会使⽤ getGeneratedKeys 的返回值
    或 insert 语句的 selectKey ⼦元素设置它的值,默认值:未设置(unset),如果⽣成列不⽌
    ⼀个,可以⽤逗号分隔多个属性名称

2.2 修改⽤户操作

mapper 接口层实现:

package com.example.demo.mapper;import com.example.demo.model.UserInfo;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;@Mapper
public interface UserInfoMapper {public int updateUserById(@Param("id") Integer ID,@Param("username") String Name);}

相应的 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">
<!--namespace 需要实现的接口的具体包名加接口名-->
<mapper namespace="com.example.demo.mapper.UserInfoMapper"><!--根据用户id 修改 姓名--><update id="updateUserById">update userInfoset username = #{username}where id = #{id};</update></mapper>

生成对应的单元测试代码:

如:修改id=42的用户名为 goodman

在这里插入图片描述

@Test
void updateUserById() {int result = userInfoMapper.updateUserById(42,"goodman");Assertions.assertEquals(1,result);
}

查看数据库:

在这里插入图片描述

显而易见,我们成功修改了用户姓名 !!


2.3 删除⽤户操作

mapper 接口层实现:

package com.example.demo.mapper;import com.example.demo.model.UserInfo;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;@Mapper
public interface UserInfoMapper {public int delUserById(@Param("id") Integer ID);Name);}

相应的 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">
<!--namespace 需要实现的接口的具体包名加接口名-->
<mapper namespace="com.example.demo.mapper.UserInfoMapper"><!--根据用户id 删除 用户--><delete id="delUserById">deletefrom userinfowhere id = #{id}</delete></mapper>

生成对应的单元测试代码:

如删除数据库 id=42 的用户信息

在这里插入图片描述

@Test
void delUserById() {int result = userInfoMapper.delUserById(42);Assertions.assertEquals(1,result);}

查看数据库:

在这里插入图片描述

显而易见,我们成功的删除了 id=42 的用户信息 !!


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_102244.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

645. 错误的集合|||697. 数组的度|||448. 找到所有数组中消失的数字

645. 错误的集合 题目 集合 s 包含从 1 到 n 的整数。不幸的是&#xff0c;因为数据错误&#xff0c;导致集合里面某一个数字复制了成了集合里面的另外一个数字的值&#xff0c;导致集合 丢失了一个数字 并且 有一个数字重复 。 给定一个数组 nums 代表了集合 S 发生错误后的…

教你轻松申请Azure OpenAI

Azure OpenAI 和 OpenAI 官方提供的服务基本是一致的&#xff0c;但是目前前者还是处于预览版的状态&#xff0c;一些功能还没有完全开放。 优点&#xff1a; 不受地域限制&#xff0c;国内可以直接调用。可以自己上传训练数据进行训练&#xff08;据说很贵&#xff09;。Azu…

Cloud Kernel SIG月度动态:发布 Anolis 8.8 镜像、kABI 社区共建流程

Cloud Kernel SIG&#xff08;Special Interest Group&#xff09;&#xff1a;支撑龙蜥内核版本的研发、发布和服务&#xff0c;提供生产可用的高性价比内核产品。 01 SIG 整体进展 Anolis 8.8 镜像发布&#xff0c;默认搭载 ANCK 5.10-013 版本。 Anolis 23 滚动内核更新至…

Windows下版本控制器(SVN)-验证是否安装成功+配置版本库+启动服务器端程序

文章目录 基础知识-Windows下版本控制器(SVN)3、Subversion 安装与配置3.1 验证是否安装成功。3.2 配置版本库3.3 启动服务器端程序 基础知识-Windows下版本控制器(SVN) 3、Subversion 安装与配置 TortoiseSVN安装与配置网上资料太多了&#xff0c;这里就不阐述了。 3.1 验证是…

【Java代码】MP3、flac歌曲批量生成同名的“xxx.lrc”歌词文件导入索尼黑砖二代

目录 1、准备条件2、实现方式3、代码环境和maven依赖4、Java代码5、示例1结果6、示例2结果7、一个小问题8、“音乐标签”下载地址 1、准备条件 网易云下载的MP3、flac后缀的歌曲若干首&#xff08;ncm后缀的歌曲需要还原格式&#xff0c;不然会随着VIP过期而无法听&#xff09…

【原理图专题】案例:从集成的电平转换芯片换成三极管分立电平转换怎么就报异常

本案例是一个已经小批量量产的设备,不是我测试出来的,但是也算是我之前一手造成的,因为原理图这部分是我修改的。 异常发现最近生产的整机有部分非接读卡时无法控制到蜂鸣器发声音。我们的设计是这样的,有两个MCU互相通信,一个MCU是控制蜂鸣器的,另一个MCU通过SPI与非接芯…

银行数字化转型导师坚鹏:银行业务数字化创新工作坊

银行业务数字化创新工作坊 课程背景&#xff1a; 很多银行存在以下问题&#xff1a; 不清楚如何进行业务数字化创新&#xff1f; 不知道如何开展银行数字化营销工作&#xff1f; 不知道零售业务数字化创新成功案例&#xff1f; 学员收获&#xff1a; 学习原创银行BLM…

docker容器内的应用利用k8s configmap做配置中心

ConfigMap 能带来什么好处&#xff1f; 传统的应用服务都有自己的配置文件&#xff0c;各自配置文件存储在服务所在节点。如果配置出现变更&#xff0c;就需要对应节点的配置文件。Kubernetes 利用了 Volume 功能&#xff0c;完整设计了一套配置中心&#xff0c;其核心对象就是…

阳光万里,祝你上岸——免统考在职研究生

什么是在职研究生 在职研究生&#xff0c;是国家计划内&#xff0c;以在职人员身份&#xff0c;部分时间在职工作&#xff0c;部分时间在校学习的研究生教育的一种类型。在职攻读硕士方式有三种&#xff1a; 1.双证非全日制研究生&#xff1a;为普通高等教育研究生学历&#x…

Android OpenGL 渲染相机预览画面显示体系

OpenGL能进行高效得渲染图形图像&#xff0c;并支持各种复杂的特效和动画。 而在 Android 当中&#xff0c;运用的是OpenGL ES&#xff0c;它是OpenGL的一个轻量级版本&#xff0c;专门用于在移动设备、游戏控制台、嵌入式系统等嵌入式环境中使用。 它可以做相机滤镜或者图片…

seata1.6.0 单机,集群搭建 基于nacos注册中心 mysql数据库

seata1.6.0 单机&#xff0c;集群搭建 基于nacos注册中心 mysql数据库 大纲 1 单机搭建2 集群搭建 由于项目中的dubbo版本为2.6.0 故客户端程序&#xff08;TM RM&#xff09;使用seata-all 1.4.2 &#xff0c;服务端&#xff08;TC&#xff09;使用seata-server-1.6.0.zip …

MIT6.S081操作系统实验2021(xv6系统)——lab1 Xv6 and Unix utilities

MIT6.S081操作系统实验2021——lab1 参考文章 sleep 要求为xv6实现UNIX 程序sleep&#xff1b;其应该暂停用户指定的ticks number。tick是 xv6 内核定义的时间概念&#xff0c;即计时器芯片的两次中断之间的时间&#xff08;两次时钟中断之间的时间&#xff09;。您的解决方…

关于函数栈帧的创建与销毁和可变参数列表

目录 1. 深刻理解函数调用过程1.1 基本概念1.2 函数栈帧的创建于销毁1.2.1 栈帧创建1.2.2 栈帧销毁1.2.3 有趣的现象 2. 了解可变参数列表的使用与原理2.1 可变参数列表与函数栈帧的关系2.2 宏的工作过程2.3 宏的具体实现原理 1. 深刻理解函数调用过程 1.1 基本概念 关于函数…

【MySQL】(7)复合查询

文章目录 单表查询回顾与练习多表查询自连接多行子查询&#xff08;单列&#xff09;in 运算符all 关键字any 关键字 多列子查询from 子句中的子查询合并查询 单表查询回顾与练习 注&#xff1a;下面的依旧基于 scott 数据库 MariaDB [scott]> select * from emp; -------…

ASEMI代理ADG736BRMZ-REEL7原装ADI车规级ADG736BRMZ-REEL7

编辑&#xff1a;ll ASEMI代理ADG736BRMZ-REEL7原装ADI车规级ADG736BRMZ-REEL7 型号&#xff1a;ADG736BRMZ-REEL7 品牌&#xff1a;ADI /亚德诺 封装&#xff1a;MSOP-10 批号&#xff1a;2023 安装类型&#xff1a;表面贴装型 引脚数量&#xff1a;10 类型&#xff1…

Mybatis框架超详解及运用总结

Mybatis 一、什么是Mybatils&#xff1f;二、第一个Mybatils程序2.1、创建springboot工程2.2、准备数据2.3、配置MyBatis2.4、编写SQL语句2.5、单元测试 三、JDBC四、数据库连接池五、lombok六、Mybatis基础操作6.1、删除6.2、新增6.2.1、主键返回 6.3、修改6.4、查询6.4.1、数…

推式配货(Push)、拉式配货(Pull)和配送需求计划(DRP)的区别

随着电子商务的迅猛发展&#xff0c;物流配送服务已然成为企业竞争最为核心的环节&#xff0c;一个全面、完善的物流配送方案&#xff0c;能够帮助企业满足客户交期、节约运输和库存成本&#xff0c;促进各环节沟通&#xff0c;提高生产稳定性。同时&#xff0c;物流配送的许多…

垃圾回收概述

什么是垃圾 垃圾收集&#xff0c;不是Java语言的伴生产物。早在1960年&#xff0c;第一门开始使用内存动态分配和垃圾收集技术的Lisp语言诞生。 关于垃圾收集有三个经典问题&#xff1a; 哪些内存需要回收&#xff1f;什么时候回收&#xff1f;如何回收&#xff1f; 垃圾收…

9.7 字符串的指针和指向字符串的指针变量

9.7 字符串的指针和指向字符串的指针变量 一.字符串表示形式二.字符串指针做函数参数1.数组名做函数参数2.数组指针做函数参数 三.字符指针变量与字符数组&#xff08;1&#xff09;字符数组是由若干个元素组成&#xff0c;每个元素中存放一个字符。&#xff08;2&#xff09;赋…

[HBZ分享] 小米手机如何解BL锁

第一步&#xff1a; 进入【设置—>我的设备–>全部参数–>连续疯狂的点MIUI版本那一行】 第二步&#xff1a;进入【更多设置–>开发者模式】&#xff0c;打开USB调试 与 USB安装 第三步&#xff1a;进入【更多设置–>开发者模式】&#xff0c;进入【设别解锁状…