目录
前言
一、增删查改操作
1、查
Ⅰ、mapper接口:
Ⅱ、UserMapper.xml 查询所有用户的具体实现 SQL:
Ⅲ、进行单元测试
2、增、删、改操作
Ⅰ、增
添加用户
添加用户并且返回自增 id
Ⅱ、改
根据id修改用户名
开启 MyBatis sql 日志打印
Ⅲ、删
二、在单元测试时不污染数据库
❤️❤️❤️SSM专栏更新中,各位大佬觉得写得不错,支持一下,感谢了!❤️❤️❤️
Spring + Spring MVC + MyBatis_冷兮雪的博客-CSDN博客
上篇我们写了一个简单的根据id进行查询,知道了如何去进行查询,下面来仔细讲讲增删改查操作。
下面操作会使用到Spring Boot单元测试,可以先看:
Spring Boot单元测试_spring boot 单元测试_冷兮雪的博客-CSDN博客
查询所有的用户:
package com.example.ssmdemo1.mapper;
import com.example.ssmdemo1.entity.Userinfo;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
@Mapper//需要添加 @Mapper 注解
public interface UserMapper {
/**
* 根据用户id查询用户信息
* @param id
* @return
*/
Userinfo getUserById(@Param("id") Integer id);
//查询所有的用户
List getAll();
}
使用$进行传递参数可能会SQL注入,所以大部分情况下是使用#的
在UserMapperTest中就有了getAll的测试代码:
添加单元测试业务逻辑
package com.example.ssmdemo1.mapper;
import com.example.ssmdemo1.entity.Userinfo;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.List;
import static org.junit.jupiter.api.Assertions.*;
@SpringBootTest//1、表明当前单元测试是运行在Spring Boot环境中的
class UserMapperTest {
//2、注入测试对象
@Autowired
private UserMapper userMapper;
@Test
void getUserById() {
//3、添加单元测试的业务代码
Userinfo userinfo=userMapper.getUserById(1);
System.out.println(userinfo);
//判断1是否等于2 简单断言
Assertions.assertEquals("admin",userinfo.getUsername());
}
@Test
void getAll() {
List list=userMapper.getAll();
Assertions.assertEquals(1,list.size());//断言判断list集合里面是否只有一条数据,即查询数据库中只有一个用户
}
}
测试正确:
如果我们没有设置resultType,则 MyBatis无法自动将查询结果映射到Java对象,这就会导致单元测试失败并报错。
与查询操作都是一样的,只是使用的标签不一样:
①、在接口(UserMapper)中声明方法
Integer add(Userinfo user);
②、UserService
public Integer getAdd(Userinfo user) {return userMapper.add(user);}
③、在xml中提供实现
insert into userinfo(username,password) values(#{username},#{password})
#{} 进行赋值使用的是对象中的属性。
注意:对应的不是数据库的字段,而是程序类中的属性。
④、controller 实现代码:
@RequestMapping(value = "/add",method = RequestMethod.POST)
public Integer add(@RequestBody Userinfo user){
return userService.getAdd(user);
}
⑤、单元测试
@Test
void add() {
//伪代码,构建对象并设置对应的值
//本来是前端传值过来
Userinfo userinfo=new Userinfo();
userinfo.setUsername("张三");
userinfo.setPassword("123456");
//调用mybatis 添加方法执行添加操作
int result=userMapper.add(userinfo);
Assertions.assertEquals(1,result);
}
单元测试成功,可以去看数据库也添加了一条数据
如果我们想在添加用户的时候同时去获取他的id,具体实现如下:
①、在接口(UserMapper)中声明方法
Integer addGetid(Userinfo user);
②、UserService
public Integer addGetid(Userinfo user) {return userMapper.addGetid(user);}
③、在xml中提供实现
insert into userinfo(username,password) values(#{username},#{password})
④、controller 实现代码:
@RequestMapping(value = "/add2", method = RequestMethod.POST)
public Integer add2(@RequestBody Userinfo user) {
userService.addGetid(user);
return user.getId();
}
⑤、单元测试
@Test
void addGetid() {
//伪代码,构建对象并设置对应的值
//本来是前端传值过来
Userinfo userinfo=new Userinfo();
userinfo.setUsername("张三");
userinfo.setPassword("123456");
//调用MyBatis 添加方法执行添加操作 返回受影响的行数
int result=userMapper.addGetid(userinfo);
int id=userinfo.getId();//得到自增id(MyBatis自动赋值)
System.out.println("id:"+id);
Assertions.assertEquals(1,result);
}
一样的代码,就一行代码不同
①、在接口(UserMapper)中声明方法
/**
* 修改用户
* @param userinfo
* @return
*/
Integer upUserName(Userinfo userinfo);
②、在xml中提供实现
update userinfo set username=#{username} where id=#{id}
③、单元测试
将之前添加的张三修改成为李四
@Test
void upUserName() {
// 构建测试数据
Userinfo userinfo = new Userinfo();
userinfo.setId(9);
userinfo.setUsername("李四");
int result = userMapper.upUserName(userinfo);
System.out.println("修改:" + result);
Assertions.assertEquals(1, result);
}
修改成功:
如果我们需要在控制台看到SQL语句,需要去配置文件进行配置,因为这默认是隐藏MyBatic生成SQL语句的细节
①、添加配置文件
# 开启 mybatis sql 日志打印
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
logging.level.com.example.demo=debug
②、重新运行单元测试
@Test
void upUserName() {
// 构建测试数据
Userinfo userinfo = new Userinfo();
userinfo.setId(9);
userinfo.setUsername("张三");
int result = userMapper.upUserName(userinfo);
System.out.println("修改:" + result);
Assertions.assertEquals(1, result);
}
执行成功:
结论: 可以看到这个就是jdbc链接,这个SQL写法也是jdbc的写法,也就是说mybatis是基于jdbc的,MyBatis使用了JDBC来与数据库进行交互,它也简化了JDBC的使用,提供了更方便的数据库访问方式。。
建议大家在开发阶段是开启SQL的打印,可以更好的帮助你找到错误。
①、在接口(UserMapper)中声明方法
int delById(@Param("id") Integer id);
②、在xml中提供实现
delete from userinfo where id=#{id}
③、单元测试
将id为9的用户删除:
@Test
void delById() {
int id=9;
int result=userMapper.delById(id);
System.out.println("删除:"+result);
Assertions.assertEquals(1,result);
}
删除成功:
在需要的地方添加注解:@Transactional(就可以修饰方法也可以修饰类)