首页 > 其他分享 >MyBatis-Plus 条件构造器(Wrapper)

MyBatis-Plus 条件构造器(Wrapper)

时间:2023-06-02 21:07:48浏览次数:44  
标签:name column age Object Wrapper --- Plus MyBatis id


接口方法的参数中,会出现各种 Wrapper,比如 queryWrapper、updateWrapper 等。Wrapper 的作用就是用于定义各种各样的条件(where)。所以不管是查询、更新、删除都会用到Wrapper
Wrapper官方文档

MyBatis-Plus系列推荐阅读顺序:

一、Wrapper的继承关系:

 

Wrapper  条件构造抽象类
    -- AbstractWrapper 查询条件封装,用于生成 sql 中的 where 语句。
        -- QueryWrapper Entity 对象封装操作类,用于查询。
        -- UpdateWrapper Update 条件封装操作类,用于更新。
        -- AbstractLambdaWrapper 使用 Lambda 表达式封装 wrapper
            -- LambdaQueryWrapper 使用 Lambda 语法封装条件,用于查询。
            -- LambdaUpdateWrapper 使用 Lambda 语法封装条件,用于更新。

MyBatis-Plus 条件构造器(Wrapper)_字段

Wrapper抽象类继承关系

说明:很多文章提到MybatisPlus的EntityWrapper,在3.0版本以上就没了,改为了QueryWrapper。

二、常用条件

【比较大小: ( =, <>, >, >=, <, <= )】

 

eq(R column, Object val); // 等价于 =,例: eq("name", "老王") ---> name = '老王'
    ne(R column, Object val); // 等价于 <>,例: ne("name", "老王") ---> name <> '老王'
    gt(R column, Object val); // 等价于 >,例: gt("name", "老王") ---> name > '老王'
    ge(R column, Object val); // 等价于 >=,例: ge("name", "老王") ---> name >= '老王'
    lt(R column, Object val); // 等价于 <,例: lt("name", "老王") ---> name < '老王'
    le(R column, Object val); // 等价于 <=,例: le("name", "老王") ---> name <= '老王'

【范围:(between、not between、in、not in)】

 

between(R column, Object val1, Object val2); // 等价于 between a and b, 例: between("age", 18, 30) ---> age between 18 and 30
   notBetween(R column, Object val1, Object val2); // 等价于 not between a and b, 例: notBetween("age", 18, 30) ---> age not between 18 and 30
   in(R column, Object... values); // 等价于 字段 IN (v0, v1, ...),例: in("age",{1,2,3}) ---> age in (1,2,3)
   notIn(R column, Object... values); // 等价于 字段 NOT IN (v0, v1, ...), 例: notIn("age",{1,2,3}) ---> age not in (1,2,3)
   inSql(R column, Object... values); // 等价于 字段 IN (sql 语句), 例: inSql("id", "select id from table where id < 3") ---> id in (select id from table where id < 3)
   notInSql(R column, Object... values); // 等价于 字段 NOT IN (sql 语句)

【模糊匹配:(like)】

 

like(R column, Object val); // 等价于 LIKE '%值%',例: like("name", "王") ---> name like '%王%'
    notLike(R column, Object val); // 等价于 NOT LIKE '%值%',例: notLike("name", "王") ---> name not like '%王%'
    likeLeft(R column, Object val); // 等价于 LIKE '%值',例: likeLeft("name", "王") ---> name like '%王'
    likeRight(R column, Object val); // 等价于 LIKE '值%',例: likeRight("name", "王") ---> name like '王%'

【空值比较:(isNull、isNotNull)】

 

isNull(R column); // 等价于 IS NULL,例: isNull("name") ---> name is null
    isNotNull(R column); // 等价于 IS NOT NULL,例: isNotNull("name") ---> name is not null

【分组、排序:(group、having、order)】

 

groupBy(R... columns); // 等价于 GROUP BY 字段, ..., 例: groupBy("id", "name") ---> group by id,name
    orderByAsc(R... columns); // 等价于 ORDER BY 字段, ... ASC, 例: orderByAsc("id", "name") ---> order by id ASC,name ASC
    orderByDesc(R... columns); // 等价于 ORDER BY 字段, ... DESC, 例: orderByDesc("id", "name") ---> order by id DESC,name DESC
    having(String sqlHaving, Object... params); // 等价于 HAVING ( sql语句 ), 例: having("sum(age) > {0}", 11) ---> having sum(age) > 11

【拼接、嵌套 sql:(or、and、nested、apply)】

 

or(); // 等价于 a or b, 例:eq("id",1).or().eq("name","老王") ---> id = 1 or name = '老王'
   or(Consumer<Param> consumer); // 等价于 or(a or/and b),or 嵌套。例: or(i -> i.eq("name", "李白").ne("status", "活着")) ---> or (name = '李白' and status <> '活着')
   and(Consumer<Param> consumer); // 等价于 and(a or/and b),and 嵌套。例: and(i -> i.eq("name", "李白").ne("status", "活着")) ---> and (name = '李白' and status <> '活着')
   nested(Consumer<Param> consumer); // 等价于 (a or/and b),普通嵌套。例: nested(i -> i.eq("name", "李白").ne("status", "活着")) ---> (name = '李白' and status <> '活着')
   apply(String applySql, Object... params); // 拼接sql(若不使用 params 参数,可能存在 sql 注入),例: apply("date_format(dateColumn,'%Y-%m-%d') = {0}", "2008-08-08") ---> date_format(dateColumn,'%Y-%m-%d') = '2008-08-08'")
   last(String lastSql); // 无视优化规则直接拼接到 sql 的最后,可能存若在 sql 注入。
   exists(String existsSql); // 拼接 exists 语句。例: exists("select id from table where age = 1") ---> exists (select id from table where age = 1)

【QueryWrapper 条件:】

 

select(String... sqlSelect); // 用于定义需要返回的字段。例: select("id", "name", "age") ---> select id, name, age
    select(Predicate<TableFieldInfo> predicate); // Lambda 表达式,过滤需要的字段。
    lambda(); // 返回一个 LambdaQueryWrapper

【UpdateWrapper 条件:】

 

set(String column, Object val); // 用于设置 set 字段值。例: set("name", null) ---> set name = null
    setSql(String sql); // 用于设置 set 字段值。例: setSql("name = '老李头'") ---> set name = '老李头'
    lambda(); // 返回一个 LambdaUpdateWrapper

三、 QueryWrapper

 

@Test
    public void testQueryWrapper() {
        // Step1:创建一个 QueryWrapper 对象
        QueryWrapper<User> queryWrapper = new QueryWrapper<>();

        // Step2: 构造查询条件
        queryWrapper
                .select("id", "name", "age")
                .lt("age", 23)//小于23岁
                .like("name", "i");//name包括i字母

        // Step3:执行查询
        userMapper
                .selectList(queryWrapper)
                .forEach(System.out::println);
    }

MyBatis-Plus 条件构造器(Wrapper)_封装_02

当前数据

MyBatis-Plus 条件构造器(Wrapper)_封装_03

SQL执行情况

四、UpdateWrapper

4.1基本语法:

set

 

set(String column, Object val)
set(boolean condition, String column, Object val)
  • SQL SET 字段
  • 例: set("name", "老李头")
  • 例: set("name", "")--->数据库字段值变为空字符串
  • 例: set("name", null)--->数据库字段值变为null

setSql

 

setSql(String sql)
  • 设置 SET 部分 SQL
  • 例: setSql("name = '老李头'")

4.2 测试

4.2.1 测试代码

 

@Test
    public void testUpdateWrapper() {
        int reduceAge = 2;
        User user = new User();

        // 更新用户数据的wrapper
        UpdateWrapper<User> updateWrapper = new UpdateWrapper<User>();
        //修改数据的语句
        updateWrapper.set("email", "[email protected]");//使email字段的值更新为“[email protected]”
        updateWrapper.setSql("age = age - " + reduceAge);//自定义的sql语句
        //条件
        updateWrapper.eq("id", 4);
        userMapper.update(user, updateWrapper);
    }

4.2.2 更新前的第4条数据:

MyBatis-Plus 条件构造器(Wrapper)_字段_04

老数据

4.2.3 执行测试代码:

MyBatis-Plus 条件构造器(Wrapper)_sql_05

SQL日志

4.2.4 更新后的第4条数据:

MyBatis-Plus 条件构造器(Wrapper)_封装_06

image.png

4.3 其他更新方法

仿照JPA更新过程,在JPA里面更新一般是先select取出数据,然后通过set方法修改entity的值,再save到数据库。
MP也提供类似的方式,见代码:

 

@Test
    public void testUpdateById() {
        User user = userMapper.selectById(4);
        user.setAge(88);
        userMapper.updateById(user);
    }

4.3.1 执行测试代码:

 

==>  Preparing: UPDATE user SET name=?, age=?, email=? WHERE id=? 
==> Parameters: Oliver(String), 88(Integer), [email protected](String), 4(Long)
<==    Updates: 1

4.3.2 更新后的第4条数据:

MyBatis-Plus 条件构造器(Wrapper)_字段_07

image.png

作者:梅西爱骑车
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

标签:name,column,age,Object,Wrapper,---,Plus,MyBatis,id
From: https://blog.51cto.com/chengzheng183/6404835

相关文章

  • MyBatis之一级缓存、二级缓存
    1、一级缓存跟踪BaseExecutor可以看到,在query方法中,实现了缓存逻辑,当缓存不存在的时候,则调用实现类中的doQuery。创建一级缓存的KEY:查看缓存中是否存在,存在则直接返回,不存在则查询数据库:查询数据库:这就是Mybatis中的一级缓存,逻辑十分简单,可以从源码中看到,一级缓存是默认开......
  • [MyBatis]DAO层只写接口,不用写实现类
    团队开发一个项目,由老大架了一个框架,遇到了DAO层不用写接口了,我也是用了2次才记住这个事的,因为自己一直都是习惯于写DAO层的实现类,所以,习惯性的还是写了个实现类。于是遇到错误了。找不到那个方法。问了团队的人才知道,方法名和Mapper中配置的id名必须一样。实现:一、配置Spring集......
  • 学Java必备EditPlus的安装与配置
    Editplus是一款很受欢迎的编辑器。简单的解释editplus软件的话,它就是一款功能更强大的记事本。除了普通的文本编辑之外,还有很多的其他特点。这篇文章详细讲讲Editplus的安装配置,配合视频观看学习效果更佳动力节点老杜的Java17版入门教程,详细讲了关于Editplus的安装配置这套JavaSE教......
  • Java入门讲解之EditPlus的安装与配置
    正好在学习java,使用到EditPlus软件,跟大家分享一下editplus的安装与配置过程:也可以直接看视频安装,B站上动力节点老杜的Java17版入门教程,详细讲了关于Editplus的安装配置学习地址:https://www.bilibili.com/video/BV1ig4y1c7kPEditPlus的安装与配置为什么不建议初学者一开始就用......
  • MyBatis常见好用的插件
    阅读文本大概需要3分钟。0x01:MybatisPageHelper分页插件在没有分页插件之前,写一个分页需要两条SQL语句,一条查询一条统计,然后才能计算出页码,这样的代码冗余而又枯燥,更重要的一点是数据库迁移,众所周知不同的数据库分页写法是不同的,而Mybatis不同于Hibernate的是它只提供动态SQL和结......
  • 在web应用中使用mybatis
    1. 实现功能:52银⾏账户转账1.1 使⽤技术:HTML + Servlet + MyBatis1.2 WEB应⽤的名称:bank2. 数据库表的设计和准备数据  523. 注意MyBatis对象作⽤域以及事务问题   573.1 MyBatis核⼼对象的作⽤域   573.1.1 SqlSessionFactoryBuilder这个类可以被实例化、使⽤......
  • 解决模块 ""element-plus"" 没有导出的成员 "ElMessage"。你是想改用 "import ElMessa
    一、问题介绍在使用vite+element-plus+ts搭建项目时,导入ElMessage组件遇到【模块""element-plus""没有导出的成员"ElMessage"。你是想改用"importElMessagefrom"element-plus""吗?】这一错误提示二、出现原因ts识别不到element-plus对外暴露的ElMessage这一类型三、解......
  • SpringBoot Vue3 Element Plus 打造分布式存储系统
    SpringBoot+Vue3+ElementPlus打造分布式存储系统download:3w51xuebccom配置IDEA热部署-devtools开发过程中频繁修改代码,每次都需要重新编译,部署,重启服务器,这无疑极大浪费了我们的时间。解决这个问题的方法就是使用热部署技术。本篇文章将介绍如何在IDEA中使用devtools实现热部署......
  • 黑马Vue3 + ElementPlus + Pinia 小兔鲜电商项目2023版
    黑马Vue3+ElementPlus+Pinia小兔鲜电商项目2023版download:3w51xuebccom合式API-watch-基本使用和立即执行合式API是一个用于构建可靠、模块化、灵活的RESTfulAPI的框架。它提供了许多实用的功能,其中包括watch机制。在本篇文章中,我们将介绍合式API的watch机制的基本使用和立......
  • mybatis 复杂类型返回
    功能:查询一个数据列表且每个数据中包含各自的子数据集合使用场景:1.当需要查询多订单数据且同时订单数据中需要包含订单明细数据时         2.当需要查询多评论数据且同时评论数据中需要包含评论回复数据时功能效果概述图:1.Dao 层定义packagecom.ljw.dao;......