ToB企服应用市场:ToB评测及商务社交产业平台

标题: MybatisPlus核心功能——实现CRUD增删改查操作 (包含条件构造器) [打印本页]

作者: 杀鸡焉用牛刀    时间: 2022-9-16 17:20
标题: MybatisPlus核心功能——实现CRUD增删改查操作 (包含条件构造器)
CRUD

官方文档:https://baomidou.com/
(建议多看看官方文档,每种功能里面都有讲解)【本文章使用的mybatisplus版本为3.5.2】
条件构造器

一般都是用service层的方法,因为比mapper层的全。十分重要:Wrapper 记住查看输出的SQL进行分析
相当于创建一个构造器对象,然后讲需要查询or更新的条件写在里面,最后打包给mapper or service层的插入、更新方法
下图是Wapper的子类,QueryWrapper和UpdateWrapper是一般的Wrapper,AbstractLambdaWrapper 是lambda语法糖的链式操作(两者选择一种使用即可)

下图是wrapper的条件方法,就不一一介绍了,下面举了六个就基本例子

1、测试一
  1. @Test
  2. public void testWrapper1() {
  3.     //参数是一个wrapper ,条件构造器,和刚才的map对比学习!
  4.     //查询name不为空,email不为空,age大于18的用户
  5.     QueryWrapper<User> wrapper = new QueryWrapper<>();
  6.     wrapper
  7.         .isNotNull("name")
  8.         .isNotNull("email")
  9.         .ge("age",18);
  10.     List<User> userList = userMapper.selectList(wrapper);
  11.     userList.forEach(System.out::println);
  12. }
复制代码
测试二
  1. @Test
  2. public void testWrapper2() {
  3.     //查询name=wsk的用户
  4.     QueryWrapper<User> wrapper = new QueryWrapper<>();
  5.     wrapper.eq("name","wsk");
  6.     //查询一个数据selectOne,若查询出多个会报错
  7.     //Expected one result (or null) to be returned by selectOne(), but found: *
  8.     //若出现多个结果使用list或map
  9.     User user = userMapper.selectOne(wrapper);//查询一个数据,若出现多个结果使用list或map
  10.     System.out.println(user);
  11. }
复制代码
测试三
  1. @Test
  2. public void testWrapper3() {
  3.     //查询age在10-20之间的用户
  4.     QueryWrapper<User> wrapper = new QueryWrapper<>();
  5.     wrapper.between("age", 10, 20);//区间
  6.     Integer count = userMapper.selectCount(wrapper);//输出查询的数量selectCount
  7.     System.out.println(count);
  8. }
复制代码
测试四
  1. @Test
  2. public void testWrapper4() {
  3.     //模糊查询
  4.     QueryWrapper<User> wrapper = new QueryWrapper<>();
  5.     wrapper
  6.         .notLike("name","s")
  7.         .likeRight("email","qq");//qq%  左和右?
  8.     List<Map<String, Object>> maps = userMapper.selectMaps(wrapper);
  9.     maps.forEach(System.out::println);
  10. }
复制代码
测试五
[code]@Testpublic void testWrapper5() {    //模糊查询    // SELECT id,name,age,email,version,deleted,create_time,update_time     //FROM user     //WHERE deleted=0 AND id IN     //(select id from user where id




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4