MyBatis-Plus(Wrapper条件查询)

Wrapper是Mybatis-plus中特有的条件封装接口

也就是把查询的条件封装到Wrapper实现类中

它的各个实现类有什么作用呢, 我觉得直接顾名思义

MyBatis-Plus(Wrapper条件查询)_第1张图片

 QueryWrapper(删,查)

@SpringBootTest
public class QueryWrapperTest{
 
    @Autowired
    UserMapper userMapper;
    QueryWrapper wrapper = new QueryWrapper<>();
 
    // 查
    @Test
    public void testGet(){
        String username = "u";
        wrapper.like(username != null, "username", username).eq("id", 1);
        // 支持链式条件
        List users = userMapper.selectList(wrapper);
        users.forEach(System.out::println);
    }
 
    // 删
    @Test
    public void testDel(){
        String username = "o";
        wrapper.like(username != null, "username", username);
        userMapper.delete(wrapper);
    }
}

因为参数一般都从前端传来的数据中得到, 所以必须用条件封装的第一个参数确认它不为null

UpdateWrapper(改)

@SpringBootTest
public class UpdateWrapperTest{
 
    @Autowired
    UserMapper userMapper;
    UpdateWrapper wrapper = new UpdateWrapper<>();
 
    // 改
    @Test
    public void test(){
        wrapper.eq("id", 13);
        User user = new User(13, "usebzar", "ziagza", "zaugz", 1);
        userMapper.update(user, wrapper);
    }
}

 

LambdaQueryWrapper(删,查)

LambdaQueryWrapper对比于QueryWrapper不同的是, 第二个参数是一个getter方法, 可以通过类名::方法名获取, 所以是很推荐使用的方法

@SpringBootTest
public class LambdaQueryWrapperTest{
 
    @Autowired
    UserMapper userMapper;
    LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>();
 
    // 查
    @Test
    public void testGet(){
        String username = "z";
        wrapper.like(username != null, User::getUsername, "z");
        // User::getUsername获取getter方法
        List users = userMapper.selectList(wrapper);
        users.forEach(System.out::println);
    }
}

LambdaUpdateWrapper(改)

应该可以从前三者中推断出它的用法了

Wrapper中的条件字段

MyBatis-Plus(Wrapper条件查询)_第2张图片

 转载于:MyBatis-Plus(三.Wrapper条件查询)_wrapper.like_z.q.xiao的博客-CSDN博客

你可能感兴趣的:(mybatis,java,tomcat)