在MyBatis Plus中QueryWrapper的使用

在MyBatis Plus中,例如,你可以使用QueryWrapper来构建查询条件,通过指定对象的非空字段来查询数据库中符合条件的记录。
首先,你需要创建一个查询条件对象 queryWrapper,然后调用QueryWrapper的entity方法,将要查询的对象作为参数传入。接下来,可以使用QueryWrapper的isNotNull方法来判断对象的每个字段是否为空,并且通过and方法进行连接,确保所有字段都不为空。

以下是一个示例代码:

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;    

// 创建 QueryWrapper 对象
QueryWrapper<YourObject> queryWrapper = new QueryWrapper<>();
YourObject yourObject = new YourObject();   

// 设置查询条件
if (yourObject.getField1() != null) {  
    queryWrapper.and(wrapper -> wrapper.isNotNull("field1")); 
}

if (yourObject.getField2() != null) {
    queryWrapper.and(wrapper -> wrapper.isNotNull("field2"));
}

// 其他字段以此类推...

// 调用 selectOne 方法执行查询
YourObject result = yourMapper.selectOne(queryWrapper);

使用QueryWrapper可以方便地进行复杂的数据库查询,包括等于、不等于、大于、小于、模糊匹配等操作。以下是QueryWrapper的一些常用方法和用法:

  1. 创建QueryWrapper对象:
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
  1. 设置查询条件:

eq:等于

queryWrapper.eq("name", "张三");

ne:不等于

queryWrapper.ne("age", 18);

gt:大于

queryWrapper.gt("age", 18);

lt:小于

queryWrapper.lt("age", 30);

ge:大于等于

queryWrapper.ge("age", 20);

le:小于等于

queryWrapper.le("age", 40);

like:模糊匹配

queryWrapper.like("name", "张");

isNull:为空

queryWrapper.isNull("email");             

isNotNull:不为空

queryWrapper.isNotNull("phone");

in:包含于

queryWrapper.in("age", Arrays.asList(18, 20, 22));

notIn:不包含于

queryWrapper.notIn("age", Arrays.asList(30, 40, 50));  

设置排序:
orderByAsc:升序排序

queryWrapper.orderByAsc("age");

orderByDesc:降序排序

queryWrapper.orderByDesc("age");

组合条件:
and:使用AND连接多个条件

queryWrapper.and(wrapper -> wrapper.like("name", "张").eq("gender",`"男"));      

or:使用OR连接多个条件

queryWrapper.or(wrapper -> wrapper.like("name", "张").eq("gender", "男"));
  1. 执行查询:

selectOne:查询一条记录

User user = userMapper.selectOne(queryWrapper);

selectList:查询多条记录

List<User> userList = userMapper.selectList(queryWrapper);  

以上是QueryWrapper的一些常用方法和用法,通过灵活运用可以构建出复杂的查询条件。在实际开发中,根据具体的需求和项目架构,可能还会使用到其他QueryWrapper的方法,如分页查询、自定义SQL查询等。可以根据具体情况进行适当的调整和扩展。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值