微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MyBatis-Plus(三.Wrapper条件查询)

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

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

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

QueryWrapper(删,查)

@SpringBoottest
public class QueryWrapperTest{

    @Autowired
    UserMapper userMapper;
    QueryWrapper<User> wrapper = new QueryWrapper<>();

    // 查
    @Test
    public void testGet(){
        String username = "u";
        wrapper.like(username != null, "username", username).eq("id", 1);
        // 支持链式条件
        List<User> 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<User> 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<User> wrapper = new LambdaQueryWrapper<>();

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

LambdaUpdateWrapper(改)

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

Wrapper中的条件字段

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐