一、增删改查记录
1.testFindAll()
运行测试类TestUserMapper里的testFindAll()测试方法,查看结果
2.testFindByName()
运行测试方法testFindByName(),查看结果
3.testInsert()
运行测试方法testInsert(),查看结果
4.testFindByName()
运行测试方法testFindByName(),查看结果
5.testUpdate()
运行测试方法testUpdate(),查看结果
6.testDeleteById()
运行测试方法testDeleteById(),查看结果
二、代码总结
package net.lsy.mybatis.mapper;
import net.lsy.mybatis.bean.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import java.io.IOException;
import java.io.Reader;
import java.util.List;
/**
* 功能:测试用户映射器接口
* 作者:lsy
* 日期:2021年03月03日
*/
public class TestUserMapper {
private SqlSession sqlSession; // SQL会话
private UserMapper userMapper; // 用户映射器
@Before
public void init() {
try {
// 读取MyBatis配置文件作为字符输入流
Reader reader = Resources.getResourceAsReader("mybatis-config.xml");
// 基于MyBatis配置文件构建SQL会话工厂
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader);
// 利用SQL会话工厂获取SQL会话
sqlSession = factory.openSession();
// 利用SQL会话获取用户映射器对象
userMapper = sqlSession.getMapper(UserMapper.class);
// 提示用户SQL会话对象创建成功
System.out.println("sqlSession对象已创建。");
} catch (IOException e) {
e.printStackTrace();
}
}
@Test
public void testFindById() {
int id = 1;
User user = userMapper.findById(id);
if (user != null) {
System.out.println(user);
} else {
System.out.println("编号为[" + id + "]的用户未找到。");
}
}
@Test
public void testFindAll() {
List<User> users = sqlSession.selectList("net.lsy.mybatis.mapper.UserMapper.findAll");
for (User user : users) {
System.out.println(user);
}
// users.forEach(user -> System.out.println(user));
}
@Test
public void testFindByName(){
String name = "王";
List<User> users = userMapper.findByName(name);
if (users.size() > 0){
users.forEach(user -> System.out.println(user));
} else {
System.out.println("姓名为[" + name + "]的记录未找到。");
}
}
@Test
public void testInsert(){
User user = new User();
user.setName("王雨涵");
user.setAge(31);
user.setAddress("龙马潭区长桥路2号");
int count = userMapper.insert(user);
sqlSession.commit();
if (count > 0) {
System.out.println("记录插入成功");
System.out.println("插入的新纪录" + user);
} else {
System.out.println("记录插入失败");
}
}
@Test
public void testUpadte(){
int id = 4;
User user = userMapper.findById(id);
System.out.println("更新前的记录:" + user);
user.setName("萌萌哒");
user.setAge(13);
user.setAddress("成都市");
int count = userMapper.update(user);
sqlSession.commit();
if (count >0) {
System.out.println("更新成功");
System.out.println("更新后的记录:" + userMapper.findById(id));
} else {
System.out.println("更新失败");
}
}
@Test
public void testDeleteById(){
int id = 4;
User user = userMapper.findById(id);
System.out.println("待删除的记录" + user);
userMapper.deleteById(id);
sqlSession.commit();
System.out.println("编号为[" + id + "[的记录删除成功");
user = userMapper.findById(id);
if (user != null){
System.out.println(user);
} else {
System.out.println("姓名为[" + id + "]的记录未找到。");
}
}
@After
public void destroy() {
// 关闭SQL会话
sqlSession.close();
// 提示用户SQL会话对象关闭
System.out.println("sqlSession对象已关闭。");
}
}