阅读 335

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


文章分类
代码人生
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐