首页 > 其他分享 >【mybatis】mybatis-plus中Wrapper(条件构造器)简介_常用方法及说明

【mybatis】mybatis-plus中Wrapper(条件构造器)简介_常用方法及说明

时间:2024-07-04 12:01:13浏览次数:27  
标签:String val column Object Wrapper 添加 plus 条件 mybatis

1、简介

  • MyBatis-Plus 是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
  • MyBatis-Plus 提供了强大的条件构造器(Wrapper),用于构建复杂的 SQL 查询条件,使得我们不必手写繁琐的 SQL 语句。
  • 这些方法主要定义在 com.baomidou.mybatisplus.core.conditions.query.QueryWrappercom.baomidou.mybatisplus.core.conditions.update.UpdateWrapper 等类中。

2、常用方法

2.1QueryWrapper(查询条件构造器)

1. 基本条件构造

  • eq(String column, Object val): 等于 =。用于添加等于条件。
  • ne(String column, Object val): 不等于 <>。用于添加不等于条件。
  • gt(String column, Object val): 大于 >。用于添加大于条件。
  • ge(String column, Object val): 大于等于 >=。用于添加大于等于条件。
  • lt(String column, Object val): 小于 <。用于添加小于条件。
  • le(String column, Object val): 小于等于 <=。用于添加小于等于条件。

2. 范围条件

  • between(String column, Object val1, Object val2): BETWEEN 值1 AND 值2。用于添加字段值在两个值之间的条件。
  • notBetween(String column, Object val1, Object val2): NOT BETWEEN 值1 AND 值2。用于添加字段值不在两个值之间的条件。

3. 模糊查询

  • like(String column, Object val): LIKE '%值%'。用于添加字段值包含某个子串的条件。
  • notLike(String column, Object val): NOT LIKE '%值%'。用于添加字段值不包含某个子串的条件。
  • likeLeft(String column, Object val): LIKE '值%'。用于添加字段值以某个子串开头的条件。
  • likeRight(String column, Object val): LIKE '%值'。用于添加字段值以某个子串结尾的条件。

4. 集合条件

  • in(String column, Collection<?> value): IN (value.get(0), value.get(1), ...)。用于添加字段值在指定集合中的条件。
  • notIn(String column, Collection<?> value): NOT IN (value.get(0), value.get(1), ...)。用于添加字段值不在指定集合中的条件。

5. 空值判断

  • isNull(String column): 字段 IS NULL。用于添加字段值为 NULL 的条件。
  • isNotNull(String column): 字段 IS NOT NULL。用于添加字段值不为 NULL 的条件。

6. 排序

  • orderByAsc(String... columns): ORDER BY 字段, ... ASC。用于添加升序排序条件。
  • orderByDesc(String... columns): ORDER BY 字段, ... DESC。用于添加降序排序条件。
  • orderBy(boolean asc, String... columns): 根据 asc 参数决定升序或降序,然后添加排序条件。

7. 分组与聚合

  • groupBy(String... columns): GROUP BY 字段,...。用于添加分组条件。
  • having(String sqlHaving, Object... params): HAVING (sqlHaving)。用于添加 HAVING 条件,支持 SQL 片段和参数。

8. 逻辑控制

  • or(): 调用此方法后,紧接着的条件会与前一个条件构成 OR 关系。注意,or() 方法仅用于逻辑控制,不会立即生成 SQL 片段,而是改变后续条件与前一个条件的逻辑关系。
  • nested(Consumer<QueryWrapper<T>> consumer): 提供一个嵌套的 QueryWrapper 来构造更复杂的条件。嵌套的条件会被视为一个整体,与其他条件通过 AND 连接(除非在嵌套内部使用了 or())。

9. 其他

  • last(String sqlLast): 将 sqlLast 拼接到 SQL 的最后,用于覆盖或追加原 SQL 条件。

2.2UpdateWrapper(更新条件构造器)

1. 设置更新条件

  • eq(String column, Object val): 等于 =。用于设置字段等于某个值的更新条件。
  • ne(String column, Object val): 不等于 <>。用于设置字段不等于某个值的更新条件。
  • gt(String column, Object val): 大于 >。用于设置字段大于某个值的更新条件。
  • ge(String column, Object val): 大于等于 >=。用于设置字段大于等于某个值的更新条件。
  • lt(String column, Object val): 小于 <。用于设置字段小于某个值的更新条件。
  • le(String column, Object val): 小于等于 <=。用于设置字段小于等于某个值的更新条件。

2. 添加更新字段

  • set(String column, Object val): 设置要更新的字段及其值。可以多次调用以设置多个字段的更新值。
  • set(Map<String, Object> columnMap): 批量设置要更新的字段及其值。通过传入一个包含字段名和字段值的 Map 对象来一次性设置多个字段的更新值。

3. 逻辑控制

  • or(): 调用此方法后,紧接着的条件会与前一个条件构成 OR 关系。

标签:String,val,column,Object,Wrapper,添加,plus,条件,mybatis
From: https://blog.csdn.net/wosixiaokeai/article/details/140171685

相关文章

  • 福利来了!MoneyPrinterPlus可以自动配置环境和自动运行了
    之前开源了MoneyPrinterPlus,可以实现批量混剪视频,一键生成视频和自动发布视频的功能。但是经常会看到小伙伴在安装过程中遇到很多问题。所以这篇文章的目的就是告诉大家怎么使用MoneyPrinterPlus的自动环境配置工具和自动启动工具。让小白用户也能用上这么好的AI工具。都是满满......
  • mybatis-plus更新数据时,字段设为null不更新
    updateById()方法不能更新字段为null,即字段为null时,对该字段不会做处理解决方式:1、自己写sql更新,不用mybatisplus的快捷方法2、使用update方法结合UpdateWrapper方式更新以上两种最简便。其他方式:2.设置全局的FieldStrategy(不推荐)#properties文件格式:mybatis-plus.glob......
  • Mybatis执行器
    mybatis执行sql语句的操作是由执行器(Executor)完成的,mybatis中一共提供了3种Executor:类型名称功能REUSE重用执行器缓存PreparedStatement,下一次执行相同的sql可重用BATCH批量执行器将修改操作记录在本地,等待程序触发或有下一次查询时才批量执行修改操作SIMPLE......
  • Mybatis使用foreach执行in语句、批量增删改查
    参考:https://www.cnblogs.com/leeego-123/p/10725210.html一、xml文件中foreach的主要属性foreach元素的属性主要有collection,item,index,separator,open,close。collection:表示集合,数据源item:表示集合中的每一个元素index:用于表示在迭代过程中,每次迭代到的位置separator:表示在......
  • mybatis的xml如何使用java枚举
    mybatis的xml如何使用java枚举使用方式${@com.haier.baseManage.enums.LoganUploadTaskTypeEnum@LOG_TYPE.type}例子<?xmlversion="1.0"encoding="UTF-8"?><!DOCTYPEmapperPUBLIC"-//mybatis.org//DTDMapper3.0//EN""http://myb......
  • springboot-mybatis-db2
    工程pom.xml文件增加如下依赖<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency><dependency>&......
  • element plus 日历组件默认中文样式,配置日期周一为周起始日
    elementui或者plus其实都是西方的展示方式,日立组件的周日视为每一周的开始日期,我们则是周日为每周的最后一天。那咱们要改成周一为每周的开始日期,如下图:elementui是可以直接属性配置的,elementplus不得行,但是配置下面代码到main.ts就可以了~importElementPlusfrom'......
  • MyBatis中的缓存
    一级缓存一级缓存默认会启用,想要关闭一级缓存可以在select标签上配置flushCache=“true”;一级缓存存在于SqlSession的生命周期中,在同一个SqlSession中查询时,MyBatis会把执行的方法和参数通过算法生成缓存的键值,将键值和查询结果存入一个Map对象中。如果同一个SqlSess......
  • 前端在for循环中使用Element-plus el-select中的@click.native动态传参
    <el-tableref="table":data="editTableVariables"@cell-dblclick="handleRowDblClick"style="width:100%"><!--el-table-column:表格列组件,定义每列的展示内容和属性--><el-table-columnprop=&q......
  • MyBatis的基本使用二
    动态SQL语句一、if判断id,userName,realName,sex,mobile,email,note,二、where字句where的作用:1.判断where中所有的条件判断成不成立,成立加where,2.第一个成立的条件去除and。anda.emaillikeCONCAT('%',#{email},'%')anda.sex=#{sex}......