Springboot系列(八):mybatis-plus条件构造器使用手册 | 超级干货,建议收藏!
嗨,家人们,我是bug菌,我又来啦。今天我们来聊点什么咧,OK,接着为大家更springboot零基础入门教学系列文章吧。帮助初学者们更好的入门!
小伙伴们如果觉得文章不错,欢迎点赞、收藏、评论,分享走一起呀,记得给bug菌来个一键三连~~
好了,我们开始这期的正文吧。
一、前言
经过上一期的mybatis-plus 入门教学,想必大家对它不是非常陌生了吧,这期呢,我主要是围绕以下几点展开,重点给大家介绍 里头的条件构造器 玩法,虽然比较容易上手,但我还是会做到句句是重点!希望小伙伴们在学习的过程中学的开心,玩的愉快!
这期教学比较干!具有很好的教学价值,希望小伙伴们根据这篇文章可以有所收获,建议小伙伴们先收藏后阅读哦。
二、如何使用构造器
前言:
QueryWrapper(LambdaQueryWrapper) 和UpdateWrapper(LambdaUpdateWrapper) 的父类是AbstractWrapper,
用于生成 sql 的 where 条件, entity 属性也用于生成 sql 的 where 条件。
注意: entity 生成的 where 条件与 使用各个 api 生成的 where 条件没有任何关联行为。
注意二者使用区别:
1). QueryWrapper: Entity 对象封装操作类 。
2). UpdateWrapper : Update 条件封装,用于Entity对象更新操作。
一般查询构造条件使用QueryWrapper,修改类型的使用UpdateWrapper
代码演练:如下分别是使用QueryWrapper 与 UpdateWrapper来进行参数传递。
/** * 根据性别查询所有用户 * * @param sex 性别 */ @Override public List getUsersBySex(String sex) { //条件构造器 QueryWrapper wrapper = new QueryWrapper<>(); //eq 代表“ = ”;例如 eq("sex", "男") ---> sex = '男';等同于拼接在sql语句后边的where条件。 wrapper.eq("sex",sex); //将条件带入查询 List list = this.list(wrapper); //返回数据 return list; } /** * 根据用户id修改用户信息 * * @param userId 用户id */ public boolean updateByUserId(String userId){ //条件构造器 UpdateWrapper wrapper = new UpdateWrapper<>(); //传入条件 wrapper.eq("id",userId); //调用修改方法 return this.update(wrapper); }复制代码
三、常用的条件构造器
#eq
eq(R column, Object val) eq(boolean condition, R column, Object val)复制代码
等于 =
例:
eq("name", "老王")
--->name = '老王'
#ne
ne(R column, Object val) ne(boolean condition, R column, Object val)复制代码
不等于 <>
例:
ne("name", "老王")
--->name <> '老王'
#gt
gt(R column, Object val) gt(boolean condition, R column, Object val)复制代码
大于 >
例:
gt("age", 18)
--->age > 18
#ge
ge(R column, Object val) ge(boolean condition, R column, Object val)复制代码
大于等于 >=
例:
ge("age", 18)
--->age >= 18
#lt
lt(R column, Object val) lt(boolean condition, R column, Object val)复制代码
小于 <
例:
lt("age", 18)
--->age < 18
#le
le(R column, Object val) le(boolean condition, R column, Object val)复制代码
小于等于 <=
例:
le("age", 18)
--->age <= 18
#between
between(R column, Object val1, Object val2) between(boolean condition, R column, Object val1, Object val2)复制代码
BETWEEN 值1 AND 值2
例:
between("age", 18, 30)
--->age between 18 and 30
#like
like(R column, Object val) like(boolean condition, R column, Object val)复制代码
LIKE '%值%'
例:
like("name", "王")
--->name like '%王%'
#notLike
notLike(R column, Object val) notLike(boolean condition, R column, Object val)复制代码
NOT LIKE '%值%'
例:
notLike("name", "王")
--->name not like '%王%'
例:
notInSql("id", "select id from table where id < 3")
--->id not in (select id from table where id < 3)
groupBy(R... columns) groupBy(boolean condition, R... columns)
分组:GROUP BY 字段, ...
例:
groupBy("id", "name")
--->group by id,name
#orderByAsc
orderByAsc(R... columns) orderByAsc(boolean condition, R... columns)复制代码
排序:ORDER BY 字段, ... ASC
例:
orderByAsc("id", "name")
--->order by id ASC,name ASC
#orderByDesc
orderByDesc(R... columns) orderByDesc(boolean condition, R... columns)复制代码
排序:ORDER BY 字段, ... DESC
例:
orderByDesc("id", "name")
--->order by id DESC,name DESC
#orderBy
orderBy(boolean condition, boolean isAsc, R... columns)复制代码
排序:ORDER BY 字段, ...
例:
orderBy(true, true, "id", "name")
--->order by id ASC,name ASC
#or
or() or(boolean condition)复制代码
拼接 OR
注意事项:
主动调用
or
表示紧接着下一个方法不是用and
连接!(不调用or
则默认为使用and
连接)例:
eq("id",1).or().eq("name","老王")
--->id = 1 or name = '老王'
... ...
想要了解更多,请参考mybatis-plus 官网哈。此处就是给大家科普下项目中常用的。
四、实例演示
先造一个wrapper构造器,然后结合我上边给的常用构造器sql文档,怎么着也得把常用的api给玩一遍吧。这样后边开发项目写起来就轻松多啦!
如下wrapper的所有方法:
五、链式调用 lambda 式
获取
LambdaWrapper
在QueryWrapper
中是获取LambdaQueryWrapper
在UpdateWrapper
中是获取LambdaUpdateWrapper
代码演示如下,改成链式写法:
public List getUsersByIdAndDate(Integer userId,Integer age){ //lambda条件构造器 LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); //传入条件 queryWrapper.eq(UserEntity::getId,userId); queryWrapper.eq(UserEntity::getAge,age); //调用修改方法 return this.list(queryWrapper); }复制代码
说白了,
lambda式玩法也一样,唯独就是你要先入门一下java8新特性之lambda表达式语法。这里就不展开讲啦,剩下来的就靠自己琢磨咯。
六、往期推荐
========================================================
Springboot<一>:零基础入门之springboot及idea搭建
Springboot<二>:零基础入门之yaml、properties配置文件介绍及实战使用
Springboot<三>:多环境切换,profile实例演示
Springboot<四>:stater入门教学
Springboot<五>:springboot之常用注解大全
Springboot<六>:mysql配置及数据库查询,实现增删改查
Springboot<七>:mybatis-plus入门及实战使用实现增删改查
伪原创工具 SEO网站优化 https://www.237it.com/
... ...
如果还想要学习更多,小伙伴们可关注bug菌专门为大家创建的专栏《SpringBoot零基础入门》,从无到有,从零到一!希望能帮到大家。
*************************************************************************************
做你想做的人,没有时间限制,只要愿意,什么时候都可以start,
你能从现在开始改变,也可以一成不变,这件事,没有规矩可言,你能活出最精彩的自己。
*************************************************************************************
OK,以上就是这期所有的内容啦,如果有任何问题欢迎评论区批评指正,咱们下期见。
作者:bug菌
链接:https://juejin.cn/post/7035113023953960991