欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 创投人物 > MyBatis-Plus 常用条件构造方法

MyBatis-Plus 常用条件构造方法

2025/11/26 21:29:15 来源:https://blog.csdn.net/sswwsm/article/details/148536237  浏览:    关键词:MyBatis-Plus 常用条件构造方法

1.常用条件方法

方法

说明
eq等于 =
ne不等于 <>
gt大于 >
ge大于等于 >=
lt小于 <
le小于等于 <=
betweenBETWEEN 值1 AND 值2
notBetweenNOT BETWEEN 值1 AND 值2
likeLIKE '%值%'
notLikeNOT LIKE '%值%'
likeLeftLIKE '%值'
likeRightLIKE '值%'
isNull字段 IS NULL
isNotNull字段 IS NOT NULL
in字段 IN (值1, 值2, ...)
notIn字段 NOT IN (值1, 值2, ...)
groupBy分组 GROUP BY 字段
orderByAsc排序 ORDER BY 字段 ASC
orderByDesc排序 ORDER BY 字段 DESC
having

HAVING (SQL语句)

这是一些使用service查询的例子

//.查询笔记作者的所有粉丝select* from tb_follow where follow_user_id = ?List<Follow> follows = followService.query().eq("follow_user_id", user.getId()).list();//扣减boolean success = seckillVoucherService.update().setSql("stock = stock - 1")//set stock=stock-1.eq("voucher_id", voucherOrder.getVoucherId()) //where id=? and stock>0.gt("stock", 0).update();

2.条件构造器

MyBatis-Plus 提供了强大的条件构造器 Wrapper,用于构建复杂的查询条件。

QueryWrapper

QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.like("name", "张").between("age", 20, 30).isNotNull("email").orderByDesc("age");
List<User> users = baseMapper.selectList(wrapper);QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("status", 1).ge("age", 18).le("age", 30).like("name", "张").orderByDesc("create_time");
List<User> user=baseMapper.selectList(queryWrapper);

LambdaQueryWrapper (推荐)

//查询20—30岁,名字有张字邮箱不为空
LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.like(User::getName, "张").between(User::getAge, 20, 30).isNotNull(User::getEmail).orderByDesc(User::getAge);List<User> users = userMapper.selectList(wrapper);// 分页查询
IPage<User> page = new Page<>(1, 10); // 当前页,每页大小
LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.ge(User::getAge, 20);
IPage<User> userPage = userMapper.selectPage(page, wrapper);

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词