Mybatis Plus 中的LambdaQueryWrapper示例详解

作者:专注写bug 时间:2023-03-26 04:52:06 

前言

之前写过 Mybatis Plus 的基本配置和使用。

Mybatis-Plus 看这一篇就够了

当初在进行查询时,虽然没有写硬SQL进行查询数据库操作,但是也不是太友好!

QueryWrapper

为什么说不够友好,客官大姥爷们先看一个例子,假设数据库中,存在一个user表,表结构呢相对简单,如下所示:

CREATE TABLE user1
(
id BIGINT(20) NOT NULL COMMENT '主键ID',
name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
age INT(11) NULL DEFAULT NULL COMMENT '年龄',
email VARCHAR(50) NULL DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (id)
);

在使用mybatis-plus查询时,只需要编写pojo类,关联映射,如下所示:

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;
@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName(value = "user1")
public class User1 implements Serializable {
   @TableId(value = "id")
   private Long id;
   @TableField(value = "name")
   private String userName;
   @TableField(value = "age")
   private Integer userAge;
   @TableField(value = "email")
   private String userEmail;
}

再编写一个持久层的mapper接口:

import cn.linkpower.pojo.User1;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.springframework.stereotype.Repository;

@Repository
public interface User1Mapper extends BaseMapper<User1> {
}

就能进行查询操作,如下所示:

import cn.linkpower.mapper.User1Mapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import lombok.extern.slf4j.Slf4j;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import javax.annotation.Resource;

@RunWith(SpringRunner.class)
@SpringBootTest
@Slf4j
public class LombokQueryTest {

@Autowired
   private User1Mapper user1Mapper;

@Test
   public void test(){
       QueryWrapper<User1> user1QueryWrapper = new QueryWrapper<>();
       user1QueryWrapper.eq("age",20);

user1Mapper.selectOne(user1QueryWrapper);
   }
}

Mybatis Plus 中的LambdaQueryWrapper示例详解

虽然很方便,但是这里需要注意一个问题:

Mybatis Plus 中的LambdaQueryWrapper示例详解

QueryWrapper中的eqin等操作,第一个参数往往是列名

【问题:】这里就引申出一个问题:

如果实际开发中表结构经常改变,岂不是涉及到变动的列名相关代码都需要改!!!!

针对上面问题的出现,可以考虑使用LambdaQueryWrapper解决!

LambdaQueryWrapper

那么现在就变更表的列名。

新建一个类似的表。

表结构如下所示:

CREATE TABLE user
(
id BIGINT(20) NOT NULL COMMENT '主键ID',
user_name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
user_age INT(11) NULL DEFAULT NULL COMMENT '年龄',
user_email VARCHAR(50) NULL DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (id)
);

INSERT INTO user (id, user_name, user_age, user_email) VALUE
(1, 'Jone', 18, 'test1@baomidou.com'),
(2, 'Jack', 20, 'test2@baomidou.com'),
(3, 'Tom', 28, 'test3@baomidou.com'),
(4, 'Sandy', 21, 'test4@baomidou.com'),
(5, 'Billie', 24, 'test5@baomidou.com');

依旧还是编写pojo类,实现映射对应关系:

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;

@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName(value = "user")
public class User2 implements Serializable {

@TableId(value = "id")
   private Long id;

@TableField(value = "user_name")
   private String userName;
   @TableField(value = "user_age")
   private Integer userAge;
   @TableField(value = "user_email")
   private String userEmail;
}

编写一个持久层的接口:

import cn.linkpower.pojo.User2;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.springframework.stereotype.Repository;

@Repository
public interface User2Mapper extends BaseMapper<User2> {
}

编写测试类:

@Autowired
private User2Mapper user2Mapper;

@Test
public void test1(){
   LambdaQueryWrapper<User2> queryWrapper = new LambdaQueryWrapper();
   queryWrapper.eq(User2::getUserName,"Jack");
   User2 users = user2Mapper.selectOne(queryWrapper);
}

测试运行:

Mybatis Plus 中的LambdaQueryWrapper示例详解

来源:https://blog.csdn.net/qq_38322527/article/details/123535539

标签:Mybatis,Plus,LambdaQueryWrapper
0
投稿

猜你喜欢

  • Android Studio常用快捷键功能说明

    2023-02-20 04:44:17
  • 在WinForm中发送HTTP请求的实现方法

    2023-01-28 10:47:35
  • Android EditText密码的隐藏和显示功能

    2021-11-17 16:49:47
  • C#操作配置文件app.config、web.config增删改

    2022-05-21 01:06:47
  • Java Http请求方式之RestTemplate常用方法详解

    2021-06-29 02:32:51
  • java_object的简单使用详解

    2023-08-22 11:35:57
  • 用代码更新你的jar包

    2023-09-19 23:01:04
  • Java 将PPT幻灯片转为HTML文件的实现思路

    2022-12-12 12:00:35
  • jenkins安装及其配置笔记

    2022-10-03 11:01:19
  • 一文详解Spring是怎么读取配置Xml文件的

    2023-07-30 00:27:37
  • android 软键盘的POPUP布局的问题解决

    2022-03-22 17:53:30
  • C#生成唯一值的方法汇总

    2023-11-09 07:25:21
  • Spring Boot2.0中SpringWebContext找不到无法使用的解决方法

    2023-05-26 02:37:01
  • idea打包java可执行jar包的实现步骤

    2022-07-30 02:57:48
  • Java基于websocket协议与netty实时视频弹幕交互实现

    2023-08-16 11:55:46
  • eclipse下配置Spring环境的方法步骤

    2023-02-27 20:39:26
  • 五分钟手撸一个Spring容器(萌芽版)

    2021-07-29 02:41:54
  • Grow heap (frag case) 堆内存过大的深入解析

    2023-04-28 15:30:27
  • 浅谈AnDroidDraw+DroidDraw实现Android程序UI设计的分析说明

    2023-09-28 20:41:51
  • C#冒泡法排序算法实例分析

    2023-08-13 18:03:42
  • asp之家 软件编程 m.aspxhome.com