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] 举报,一经查实,本站将立刻删除。