【MyBatis-Plus】(8)条件构造器

一、条件构造器

官方文档:条件构造器

条件抽象类 Wrapper非常重要。他的子类AbstractWrapper有非常多方法。一些复杂的sql条件就可以使用"*AbstractWrapper"的子类来替代!

例如,WHERE 子句的一些条件查询。

1.QueryWrapper 使用

QueryWrapper 对象主要用于查询时设置条件。

主要参考官方,下列代码供参考,使用的还是之前的user数据库。

@SpringBootTest
public class WrapperTest {
    @Autowired
    UserMapper userMapper;

    @Test
    public void t1() {
        // 查询年龄等于20的用户,且名字不等于'123'的用户
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper.eq("age", 20).ne("name", "123");
        List<User> users = userMapper.selectList(wrapper);
        users.forEach(System.out::println);
    }

    @Test
    public void t2() {
        // 查询id大于3,且年龄大于等于18的用户
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper.gt("id", 3).ge("age", 18);
        List<User> users = userMapper.selectList(wrapper);
        users.forEach(System.out::println);
    }

    @Test
    public void t3() {
        // 查询id小于10,且年龄小于等于20的用户
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper.lt("id", 10).le("age", 20);
        List<User> users = userMapper.selectList(wrapper);
        users.forEach(System.out::println);
    }

    @Test
    public void t4() {
        // 查询id在1-10,且年龄不在0-20和30-40的用户
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper.between("id", 1, 10).notBetween("age", 0, 20)
                .notBetween("age", 30, 40);
        List<User> users = userMapper.selectList(wrapper);
        users.forEach(System.out::println);
    }

    @Test
    public void t5() {
        // 查询邮箱包含test,名字不包含张三的用户
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper.like("email", "test").notLike("name", "张三");
        List<User> users = userMapper.selectList(wrapper);
        users.forEach(System.out::println);
    }

    @Test
    public void t6() {
        // 查询id为1,2,3,4,5,查询结果降序排序。
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper.in("id", 1,2,3,4,5).orderByDesc("id");
        List<User> users = userMapper.selectList(wrapper);
        users.forEach(System.out::println);
    }

    @Test
    public void t7() {
        // 查询id在指定值的用户。(指定值使用sql语句进行查询)
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper.inSql("id", "SELECT id FROM user WHERE id <= 3");
        List<User> users = userMapper.selectList(wrapper);
        users.forEach(System.out::println);
    }
}

官方文档中的方法作用解释图:

在这里插入图片描述

上图图参考自他人博客:链接

2.UpdateWrapper 使用

UpdateWrapper 可以用于更新操作,更新数据为指定的值。

    @Test
    public void t8() {
        // 将所有创建时间设置为当前时间
        UpdateWrapper<User> wrapper = new UpdateWrapper<>();
        wrapper.set("create_time", new Date());

        userMapper.update(null, wrapper);
    }

至此,条件构造器 Wrapper已结束。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Mybatis-Plus条件构造器是一种方便的查询条件构造工具,可以通过链式调用的方式构造出复杂的查询条件。它支持多种查询条件,包括等于、不等于、大于、小于、模糊查询等,还可以通过Lambda表达式来构造查询条件,使得代码更加简洁易懂。同时,Mybatis-Plus条件构造器还支持分页查询、排序等功能,可以满足大部分的查询需求。 ### 回答2: Mybatis-Plus 是一款增强 Mybatis 功能的开发包,它提供了很多便捷的操作方式以简化 Mybatis 的开发,其中条件构造器就是其中之一。 Mybatis-Plus条件构造器能够帮助我们构建查询条件,使我们省去了手写 SQL 语句的烦恼。在使用条件构造器之前,我们需要先导入依赖包。 下面是条件构造器的创建方式: Wrapper wrapper = new WrapperBuilder().and("name={0}", "Lucy").and("age>{0}", 18).build(); 其中,WrapperBuilder 是构造器的构建工具类,and() 方法用于添加多个条件。构建条件之后,我们可以将条件传递给 Mybatis-Plus 的查询方法进行查询操作。 除了上述的构建方式,条件构造器还支持 QueryWrapper、UpdateWrapper 和 LambdaQueryWrapper 等多种构建方式,不同的构建方式可以满足不同的查询需求。 使用 Mybatis-Plus条件构造器,我们可以通过灵活的组合多个查询条件,快速地构建满足我们需求的 SQL 语句。同时,在实际使用过程中,我们还需要注意一些常见的使用技巧: 1. 使用占位符。在构建 SQL 语句时,我们需要使用占位符来避免 SQL 注入的风险。 2. 处理字段映射。在使用条件构造器时,需要注意数据库表名和实体类属性名之间的映射关系。如果两者不一致,需要进行处理。 3. 处理关联表查询。当我们需要查询多张表时,需要通过关联查询的方式来完成,并且需要处理好关系的映射。 总之,Mybatis-Plus条件构造器能够为我们节约很多时间和精力。当然,在使用时需要注意一些使用技巧,以便更好地发挥它的能力。 ### 回答3: MyBatis-Plus是一个基于MyBatis的增强工具,为MyBatis提供了更加便捷、高效的持久层操作方式。它的条件构造器是其中一个功能强大的组件,用于链式构建SQL查询条件,无需手动拼接SQL语句,提高了代码可读性和可维护性。 条件构造器提供了多种查询方式,包括等于、大于、小于、in、between、like等,可以满足大部分的查询需求。我们可以通过Lambda表达式来指定查询条件,这种方式比传统的字符串拼接更加安全、可读,可以少写一些防注入的代码。 MyBatis-Plus条件构造器还支持分页查询,可以通过Page对象指定当前页码、每页显示数量等,方便地实现分页查询。同时,条件构造器也支持排序、自定义SQL片段等功能,使得查询功能更加多样化和灵活。 除了条件构造器MyBatis-Plus还提供了其他很多方便的功能,例如注解式CRUD、自动代码生成等。相信在项目开发中使用MyBatis-Plus可以极大地提高开发效率和代码质量,使得持久层操作更加简洁、优雅。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值