MyBatis-Plus使用条件构造器实现不同条件的查询,更新删除操作

Wrapper 是所有条件构造器的父类,作用是生成条件语句,即where后面的sql子句

在调用查询,更新,删除操作时,需要根据条件进行判断,可以使用条件构造器进行组合条件,生成where后面条件子句

QueryWrapper,UpdateWrapper

LambdaQueryWrapper,LambdaUpdateWrapper

UpdateWrapper提供了set方法,可以设置更新后的数据
QueryWrapper,可以对查询,更新,删除操作进行条件组合

LambdaQueryWrapper、LambdaUpdateWrapper支持Lambda表达式,可以通过Lambda表达式获取到对应的字段,省去字段名的编写

有Lambda前缀的,表示支持Lambda表达式

application.yml

server:
  port: 8080

  #数据源配置
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/mybatisplus212?characterEncoding=utf-8&serverTimezone=UTC
    username: root
    password: 123456

    type: com.zaxxer.hikari.HikariDataSource
mybatis-plus:
  configuration:
    #配置日志信息
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    #配置mapper映射文件的位置,默认在类路径/mapper*.xml
  mapper-locations: classpath:/mapper/*.xml
  #设置指定包下所有类设置类型别名
  type-aliases-package: com.dzqc.pojo
  global-config:
    db-config:
      #统一设置实体类对应的数据表的默认前缀
      table-prefix: t_
      #设置主键自增
      id-type: auto

Wrapper测试类

package com.dzqc;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.dzqc.pojo.User;
import com.dzqc.service.IUserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.List;

/**
 * 测试条件构造器
 * 组合where后面条件子句
 * QueryWrapper
 * UpdateWrapper
 */
@SpringBootTest
public class WrapperTest {

    @Autowired
    private IUserService userService;

    @Test
    public void testWapperTest(){
        //根据id查询用户信息
        //select*from t_user  where id=4
        //创建条件构造器
        QueryWrapper<User> objectQueryWrapper = new QueryWrapper<>();
        //组合条件 连缀操作
        objectQueryWrapper.eq("u_id",4)
                .likeRight("u_name","李")
                .ge("age",20)
                .isNotNull("email");
        List<User> list = userService.list(objectQueryWrapper);
        System.out.println("list = " + list);
    }
    //测试 并且 或者 条件
    @Test
    public void testWrapper(){
        //更新  年龄大于20 或者 邮箱不为空的  用户姓名 为  小章
        // UPDATE t_user SET u_name=? WHERE is_delete=0 AND (age > ? OR email IS NULL)
        //创建 条件构造器
        UpdateWrapper<User> updateWrapper = new UpdateWrapper<>();
        updateWrapper.gt("age",25)
                .or()
                .isNull("email");
        //更新后用户数据
        User user = new User();
        user.setName("李华");
        boolean update = userService.update(user, updateWrapper);
        System.out.println("update = " + update);
    }
    //测试删除
    @Test
    public void testWrappper2(){
        QueryWrapper<User> objectQueryWrapper = new QueryWrapper<>();
        objectQueryWrapper.eq("u_id",2).or().isNotNull("age");
        boolean remove = userService.remove(objectQueryWrapper);
        System.out.println("remove = " + remove);
    }
    @Test
    public void testWrapper3(){
        LambdaQueryWrapper<User> objectLambdaQueryWrapper = new LambdaQueryWrapper<>();
        objectLambdaQueryWrapper.ge(User::getId,2)
                .likeRight(User::getName,"李")
                .ge(User::getAge,24)
                .isNotNull(User::getEmail);

        List<User> list = userService.list(objectLambdaQueryWrapper);
        list.forEach(System.out::println);
    }
    @Test
    public void testWrapper7(){
        //更新
        LambdaUpdateWrapper<User> objectLambdaUpdateWrapper = new LambdaUpdateWrapper<>();
        objectLambdaUpdateWrapper.isNull(User::getEmail);
        //更新后数据
        objectLambdaUpdateWrapper.set(User::getAge,18);
        boolean update = userService.update(null, objectLambdaUpdateWrapper);
        System.out.println("update = " + update);
    }
    @Test
    public void testWrapper8(){
        Integer age=19;
        //查询年龄不为空的用户信息,进行删除
        LambdaUpdateWrapper<User> lambdaUpdateWrapper = new LambdaUpdateWrapper<>();
        lambdaUpdateWrapper.eq(User::getName,"王五")
                .or()
                .isNotNull(User::getEmail)
                .isNotNull(User::getAge);
        boolean remove = userService.remove(lambdaUpdateWrapper);
        System.out.println("remove = " + remove);

    }
}

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Mybatis-Plus条件构造器是一种方便的查询条件构造工具,可以通过链式调用的方式构造出复杂的查询条件。它支持多种查询条件,包括等于、不等于、大于、小于、模糊查询等,还可以通过Lambda表达式来构造查询条件,使得代码更加简洁易懂。同时,Mybatis-Plus条件构造器还支持分页查询、排序等功能,可以满足大部分的查询需求。 ### 回答2: Mybatis-Plus 是一款增强 Mybatis 功能的开发包,它提供了很多便捷的操作方式以简化 Mybatis 的开发,其中条件构造器就是其中之一。 Mybatis-Plus条件构造器能够帮助我们构建查询条件,使我们省去了手写 SQL 语句的烦恼。在使用条件构造器之前,我们需要先导入依赖包。 下面是条件构造器的创建方式: Wrapper wrapper = new WrapperBuilder().and("name={0}", "Lucy").and("age>{0}", 18).build(); 其中,WrapperBuilder 是构造器的构建工具类,and() 方法用于添加多个条件。构建条件之后,我们可以将条件传递给 Mybatis-Plus查询方法进行查询操作。 除了上述的构建方式,条件构造器还支持 QueryWrapperUpdateWrapper 和 LambdaQueryWrapper 等多种构建方式,不同的构建方式可以满足不同查询需求。 使用 Mybatis-Plus条件构造器,我们可以通过灵活的组合多个查询条件,快速地构建满足我们需求的 SQL 语句。同时,在实际使用过程中,我们还需要注意一些常见的使用技巧: 1. 使用占位符。在构建 SQL 语句时,我们需要使用占位符来避免 SQL 注入的风险。 2. 处理字段映射。在使用条件构造器时,需要注意数据库表名和实体类属性名之间的映射关系。如果两者不一致,需要进行处理。 3. 处理关联表查询。当我们需要查询多张表时,需要通过关联查询的方式来完成,并且需要处理好关系的映射。 总之,Mybatis-Plus条件构造器能够为我们节约很多时间和精力。当然,在使用时需要注意一些使用技巧,以便更好地发挥它的能力。 ### 回答3: MyBatis-Plus是一个基于MyBatis的增强工具,为MyBatis提供了更加便捷、高效的持久层操作方式。它的条件构造器是其中一个功能强大的组件,用于链式构建SQL查询条件,无需手动拼接SQL语句,提高了代码可读性和可维护性。 条件构造器提供了多种查询方式,包括等于、大于、小于、in、between、like等,可以满足大部分的查询需求。我们可以通过Lambda表达式来指定查询条件,这种方式比传统的字符串拼接更加安全、可读,可以少写一些防注入的代码。 MyBatis-Plus条件构造器还支持分页查询,可以通过Page对象指定当前页码、每页显示数量等,方便地实现分页查询。同时,条件构造器也支持排序、自定义SQL片段等功能,使得查询功能更加多样化和灵活。 除了条件构造器MyBatis-Plus还提供了其他很多方便的功能,例如注解式CRUD、自动代码生成等。相信在项目开发中使用MyBatis-Plus可以极大地提高开发效率和代码质量,使得持久层操作更加简洁、优雅。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kongbaidaima

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值