【java】Maybatis-Plus 数据库查询 lambdaQuery和mapper中EQ、NE、GT、LT、GE、LE、select、like、in、leftjoin的用法及详解

这篇具有很好参考价值的文章主要介绍了【java】Maybatis-Plus 数据库查询 lambdaQuery和mapper中EQ、NE、GT、LT、GE、LE、select、like、in、leftjoin的用法及详解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Maybatis-Plus lambdaQuery和mapper中EQ、NE、GT、LT、GE、LE的用法及详解

实体

当前实体如下,后续代码示例都用该实体;

@Data
@TableName("user_info")
@ApiModel(value = "UserInfo对象", description = "")
public class UserInfo implements Serializable {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty(value = "id")
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    @ApiModelProperty(value = "用户编号")
    private String userCode;

    @ApiModelProperty(value = "用户名称")
    private String userName;

    @ApiModelProperty(value = "年龄")
    private Integer age;
    }

1.EQ:等于

EQ 是 EQUAL 的缩写,表示等于

userInfoService.lambdaQuery().eq(UserInfo::getAge, 10);
userInfoMapper.selectOne(new QueryWrapper<UserInfo>().lambda().eq(UserInfo::getUserName, "沙一汀"));

2.NE:不等于

NE 是 NOT EQUAL的缩写,表示不等于

userInfoService.lambdaQuery().ne(UserInfo::getAge, 10);
userInfoMapper.selectOne(new QueryWrapper<UserInfo>().lambda().ne(UserInfo::getUserName, "沙一汀"));

3.GT:大于

GT 是 GREATER THAN 的 缩写,表示大于

userInfoService.lambdaQuery().gt(UserInfo::getAge, 10);

4.LT:小于

LT 是 LESS THAN 的缩写,表示小于

userInfoService.lambdaQuery().lt(UserInfo::getAge, 10);

5.GE:大于等于

GE 是 GREATER THAN OR EQUAL 的缩写,表示大于等于

userInfoService.lambdaQuery().ge(UserInfo::getAge, 10);

6.LE:小于等于

LE 是 LESS THAN OR EQUAL 的缩写,表示小于等于

userInfoService.lambdaQuery().le(UserInfo::getAge, 10);

7.两个对象是否相交

if ((!start1.after(end2)) && (!end1.before(start2))) {
			System.out.println("时间重叠");
		}

8. select

  • select():查询指定的字段,支持可变长参数同时查询多个字段,但是在同一个
  • select:只能查询相同表的字段,所以如果查询多张表的字段需要分开写

更多详情:https://blog.csdn.net/weixin_43906569/article/details/107813941

8.1 selectList:

按条件查询,返回list集合

userInfoMapper.selectList(new QueryWrapper<UserInfo>().lambda().ne(UserInfo::getUserName, "沙一汀"));

8.1 selectOne:查一条数据

个人理解:从数据库表中查询出一条数据。
注意:如果需要将selectOne的返回值传递进行操作的话,必须考虑可能的返回null的情况,否则程序就会异常。

userInfoMapper.selectOne(new QueryWrapper<UserInfo>().lambda().ne(UserInfo::getUserName, "沙一汀"));

8.2 selectAll:查全部字段

个人理解:查询指定实体类的全部字段。

MPJLambdaWrapper<UserInfo> lambdaWrapper = new MPJLambdaWrapper();
lambdaWrapper.selectAll(UserInfo.class);

8.3 selectAs:字段别名查询

用于数据库字段与接收结果的dto中属性名称不一致时转换

MPJLambdaWrapper<UserInfo> lambdaWrapper = new MPJLambdaWrapper();
lambdaWrapper.selectAs(Diction::getDicValue, UserInfo::getDataTypeName);

9. leftJoin:左连接

左关联查询,其中第一个参数是参与联表的表对应的实体类,第二个参数是这张表联表的ON字段,第三个参数是参与联表的ON的另一个实体类属性。

除此之外,还可以正常调用mybatis-plus中的各种原生方法,文档中还提到,默认主表别名是t,其他的表别名以先后调用的顺序使用t1、t2、t3以此类推。

MPJLambdaWrapper<UserInfo> lambdaWrapper = new MPJLambdaWrapper();
lambdaWrapper.leftJoin(Department.class, Department::getId, UserInfo::getDeptId);

10. in

常用于条件查询,筛选出某属性值在某一区间内的所有数据。

MPJLambdaWrapper<UserInfo> lambdaWrapper = new MPJLambdaWrapper();
lambdaWrapper.in(UserInfo::getDeptId, UserInfo.getDeptIds());

11. like:模糊查询

MPJLambdaWrapper<UserInfo> lambdaWrapper = new MPJLambdaWrapper();
lambdaWrapper.like(UserInfo::getSpatialName, userInfoParam.getSpatialName());

12. 示例

拼接sql语句,用于查询数据库。

user表关联部门表department;
user表关联字典表diction
UserUtils 为登录用户操作类

private MPJLambdaWrapper conditionalSplicing(UserInfoParam userInfoParam) {
        MPJLambdaWrapper<UserInfo> lambdaWrapper = new MPJLambdaWrapper();
        lambdaWrapper.selectAll(UserInfo.class)
                .select(Department::getDeptName)		
                .selectAs(Diction::getDicValue, UserInfo::getDataTypeName)
                .leftJoin(Department.class, Department::getId, UserInfo::getDeptId)
                .leftJoin(Diction.class, Diction::getDicKey, UserInfo::getDataType)
                .eq(Diction::getDicType,"spatialDataType")
	            .eq(Diction::getDeptId,UserUtils.getRootDeptId());
        if (CollectionUtils.isNotEmpty(userInfoParam.getDeptIds())) {
            lambdaWrapper.in(UserInfo::getDeptId, UserInfo.getDeptIds());
        }
        if (StringUtils.isNotBlank(userInfoParam.getSpatialName())) {
            lambdaWrapper.like(UserInfo::getSpatialName, userInfoParam.getSpatialName());
        }
        if (userInfoParam.dataType != null) {
            lambdaWrapper.eq(UserInfo::getDataType, userInfoParam.getDataType());
        }
        return lambdaWrapper;
    }

补充资料:https://baijiahao.baidu.com/s?id=1739288190028141274&wfr=spider&for=pc文章来源地址https://www.toymoban.com/news/detail-461498.html

到了这里,关于【java】Maybatis-Plus 数据库查询 lambdaQuery和mapper中EQ、NE、GT、LT、GE、LE、select、like、in、leftjoin的用法及详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【java爬虫】将优惠券数据存入数据库排序查询

    本文是在之前两篇文章的基础上进行写作的 (1条消息) 【java爬虫】使用selenium爬取优惠券_haohulala的博客-CSDN博客 (1条消息) 【java爬虫】使用selenium获取某宝联盟淘口令_haohulala的博客-CSDN博客  前两篇文章介绍了如何获取优惠券的基础信息,本文将获取到的基本信息存到数据库中

    2024年02月16日
    浏览(53)
  • java八股文面试[数据库]——慢查询优化

    分析慢查询日志 直接分析慢查询日志, mysql使用 explain + sql语句进行模拟优化器来执行分析。 oracle使用explain plan for + sql语句进行模拟优化器来执行分析。 table | type | possible_keys | key |key_len | ref | rows | Extra EXPLAIN列的解释: table 显示这一行的数据是关于哪张表的 type 这是重要的

    2024年02月10日
    浏览(38)
  • Java提升数据库大数据查询速度的几种方式

    本文章以MySQL数据库为用例说明,列举出几个常用的提升查询速度的方式。 分页查询,在网络浏览中,经常会看到分页的使用,像百度搜索分页、文档资料分页等,这些都是一种常见的提升数据查询速度和用户体验的一种方式,数据库有limit,开发人员可使用此

    2024年02月12日
    浏览(60)
  • Java EE 突击 13 - MyBatis 查询数据库(2)

    这个专栏给大家介绍一下 Java 家族的核心产品 - SSM 框架 JavaEE 进阶专栏 Java 语言能走到现在 , 仍然屹立不衰的原因 , 有一部分就是因为 SSM 框架的存在 接下来 , 博主会带大家了解一下 Spring、Spring Boot、Spring MVC、MyBatis 相关知识点 并且带领大家进行环境的配置 , 让大家真正用好

    2024年02月11日
    浏览(51)
  • java serverlets使用数据源连接oracle数据库,并执行查询操作代码

    package chap03; import java.io.IOException; import java.io.PrintWriter; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.PreparedStatement; import java.sql.Statement; import java.util.*; import javax.naming.Context; import javax.naming.InitialContext; import javax.naming.Namin

    2024年02月08日
    浏览(55)
  • 【Java】Mybatis查询数据库返回JSON格式的字段映射到实体类属性

    今天遇到了一个bug,大概就是数据库(Mysql)中有一个 type 类型字段,数据类型为json,大概是这样的:[“苹果”,“香蕉”,“葡萄”]的数据格式,这个bug的问题所在呢就是查询后这个json格式的数据无法映射到我们实体类的属性上,解决方案如下: 实体类的配置: @TableField

    2024年02月15日
    浏览(48)
  • Mybaits:数据库查询类型不匹配,java.sql.SQLDataException: Cannot determine value type from string

    目录 一.问题描述 二.源码分析 三.总结 事情的起因是用MybaitsPlus查询数据库过程中,查询结果与要封装的实体类字段类型对应不上,类似这样: 数据库查询结果: java实体类: 字段名字和实体类的名字类型都能对应上,但最后的查询结果却会报错java.sql.SQLDataException: Cannot d

    2024年02月03日
    浏览(67)
  • JSP 学生成绩查询管理系统eclipse开发sql数据库serlvet框架bs模式java编程MVC结构

    一、源码特点   JSP 学生成绩查询管理系统 是一套完善的web设计系统,对理解JSP java编程开发语言有帮助,比较流行的servlet框架系统具有完整的源代码和数据库,eclipse开发系统主要采用B/S模式 开发。 java 学生成绩查询管理系统 代码下载链接 https://download.csdn.net/download/qq_412

    2024年02月05日
    浏览(67)
  • Java中通过List中的stream流去匹配相同的字段去赋值,避免for循环去查询数据库进行赋值操作

    Q :上面两个列表怎么使用流,根据equipmentDeviceMessageInfo中的phone字段去匹配userList 中的phone字段再获取userList 中是name赋值给equipmentDeviceMessageInfo 中的name。 A :以前的写法是通过for循环遍历一个一个去查询赋值,这样的话如果数据多的话一个一个遍历会查询的话肯定是很慢的,

    2024年02月07日
    浏览(48)
  • MyBatis Plus 数据库字段加密处理

    当项目开发到一半,可能突然客户会要求对数据库里面比如手机号、身份证号的字段进行加密; 在保证开发最快、影响范围最小的情况下,我们需要选择一种介于数据库和代码之间的工具来帮我们实现自动加解密; 这里我们选用AES对称加密算法,因为它是可逆算法。 AES加密

    2024年02月07日
    浏览(63)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包