MyBatisPlus(十一)包含查询:in

说明

包含查询,对应SQL语句中的 in 语句,查询参数包含在入参列表之内的数据。

in

    @Test
    void inNonEmptyList() {
        // 非空列表,作为参数
        List<Integer> ages = Stream.of(18, 20, 22).collect(Collectors.toList());
        in(ages);
    }


    @Test
    void inEmptyList() {
        // 空列表,作为参数
        List<Integer> ages = new ArrayList<>();
        in(ages);
    }


    /**
     * 查询用户列表, 查询条件:年龄包含在参数列表之内。
     * <br>
     * 入参不为空和空列表时,“包含”条件生效。
     */
    void in(List<Integer> ages) {
        LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
        wrapper.in(!CollectionUtils.isEmpty(ages), User::getAge, ages);
        List<User> users = mapper.selectList(wrapper);
        log.info(users.toString());
    }
  • 非空列表,作为参数

在这里插入图片描述

  • 空列表,作为参数

在这里插入图片描述

notIn

    /**
     * 查询用户列表, 查询条件:年龄不包含在参数列表之内。
     */
    @Test
    void notIn() {
        List<Integer> ages = Stream.of(18, 20, 22).collect(Collectors.toList());
        LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
        wrapper.notIn(!CollectionUtils.isEmpty(ages), User::getAge, ages);
        List<User> users = mapper.selectList(wrapper);
        log.info(users.toString());
    }

在这里插入图片描述

inSql

不建议使用此方法。建议直接使用原生 MyBatis 去写SQL。

    /**
     * 查询用户列表, 查询条件:年龄包含在"sql语句的查询结果"之内。
     */
    @Test
    void inSql() {
        LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
        wrapper.inSql(User::getAge, "select age from tb_user where age > 25");
        List<User> users = mapper.selectList(wrapper);
        log.info(users.toString());
    }

在这里插入图片描述

notInSql

不建议使用此方法。建议直接使用原生 MyBatis 去写SQL。

    /**
     * 查询用户列表, 查询条件:年龄不包含在"sql语句的查询结果"之内。
     */
    @Test
    void notInSql() {
        LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
        wrapper.notInSql(User::getAge, "select age from tb_user where age > 25");
        List<User> users = mapper.selectList(wrapper);
        log.info(users.toString());
    }

在这里插入图片描述

数据库内的数据

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宋冠巡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值