Mybatis Plus 中的LambdaQueryWrapper示例详解
作者:专注写bug 发布时间:2023-03-26 04:52:06
标签:Mybatis,Plus,LambdaQueryWrapper
前言
之前写过 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);
}
}
虽然很方便,但是这里需要注意一个问题:
QueryWrapper
中的eq
、in
等操作,第一个参数往往是列名
!
【问题:】
这里就引申出一个问题:
如果实际开发中表结构经常改变,岂不是涉及到变动的列名相关代码都需要改!!!!
针对上面问题的出现,可以考虑使用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);
}
测试运行:
来源:https://blog.csdn.net/qq_38322527/article/details/123535539


猜你喜欢
- 本文实例讲述了C#同步网络时间的方法。分享给大家供大家参考。具体分析如下:客户的机器的系统时间经常出错,导致给他们做的软件无法正常使用,所以
- Lucene提供了一个简单却强大的应用程序接口(API),能够做全文索引和搜寻,在Java开发环境里Lucene是一个成熟的免费开放源代码工
- 说明:基于atguigu学习笔记。在了解spring boot自动配置原理前,再来了解下两个注解@Import注解和@Conditional
- AES类时微软MSDN中最常用的加密类,微软官网也有例子,参考链接:https://docs.microsoft.com/zh-cn/dot
- volatile关键字相信了解Java多线程的读者都很清楚它的作用。volatile关键字用于声明简单类型变量,如int、float、boo
- G1 – Garbage First(垃圾优先算法)G1最主要的设计目标是: 将STW停顿的时间和分布变成可预期以及可配
- 平时,我们将c#中的Distinct大多用于对数组去重,一般数组为基础的数据类型,例如 int,string.也可以用于对象去重,我们看看C
- 具体实现过程请看下面代码:简单的调用了一下系统的拍照功能代码如下所示://拍照的方法 private void openTakePhoto(
- java和javascript长得是如此地相像,那么它们是一回事儿吗?现在让我来揭晓答案吧!JavaScript 是一种嵌入式脚本文件,直接
- Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。它与 JSP,Velocity,FreeMaker 等模
- List去重复,我们首先想到的可能是 利用List转Set集合,因为Set集合不允许重复。所以达到这个目的。 如果集合里面是简单对
- 本文实例讲述了C#使用Object类实现栈的方法。分享给大家供大家参考,具体如下:Stack类的代码:using System;using
- 测试代码pom.xml:<?xml version="1.0" encoding="UTF-8"
- 一. 为什么要使用接口假如有一个需求:要求实现防盗门的功能。门有"开"和"关"的功能,锁有"
- 一、背景今天有小伙伴面试的时候被问到:Spring AOP中JDK 和 CGLib * 哪个效率更高?二、基本概念首先,我们知道Sprin
- 序目前最新的版本是 C# 7.0,VS 的最新版本为 Visual Studio 2017 RC,两者都尚未进入正式阶段。C# 6.0 虽说
- 在进行一个表达式的计算时,先将表达式分割成数字和字符串然后利用出入栈将分割后的表达式进行中缀转后缀,再将后缀表达式进行计算得到结果(思想在上
- 修改readme.txt文件如下:Git is a distributed version control system.Git is fr
- 今天,简单讲讲如何监听手机屏幕是否锁屏。实现方法:1)通过BroadcastReceiver接收广播Intent.ACTION_SCREEN
- hibernate一级缓存和二级缓存的区别缓存是介于应用程序和物理数据源之间,其作用是为了降低应用程序对物理数据源访问的频次,从而提高了应用