Mybatis-Plus查询中如何排除标识字段

 更新时间:2021年06月21日 11:27:41   作者:DT辰白  
这篇文章主要介绍了Mybatis-Plus查询中排除标识字段的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

一、查询中排除标识字段

1.1 测试查询

@Test
public void findAllTest() {
    List<User> userList = userMapper.selectList(null);
    userList.forEach(System.out::println);
}

1.2 实体类字段不添加@TableField注解

//逻辑删除注解(0 未删除 1 已删除)
@TableLogic
/*@TableField(select = false)*/
private Boolean isDeleted;

在没有加注解的情况下,is_deleted在查询中存在

Preparing: SELECT id,name,email,age,status,is_deleted,version FROM user WHERE is_deleted=0

1.3 实体类字段添加@TableField注解

//逻辑删除注解(0 未删除 1 已删除)
@TableLogic
@TableField(select = false)
private Boolean isDeleted;

在加注解的情况下,is_deleted在查询中不存在

Preparing: SELECT id,name,email,age,status,version FROM user WHERE is_deleted=0

二、查询中排除标识字段,自定义方法时需要注意

比如:自定义,查询年龄大于xxx岁的,返回list集合

@Test
public void mySelectTest() {
    // 查询年龄大于xxx岁的
    List<User> userList = userMapper.mySelectList(Wrappers.<User>lambdaQuery()
            .gt(User::getAge,1));
    userList.forEach(System.out::println);
}
@Select("select * from user ${ew.customSqlSegment}")
List<User> mySelectList(@Param(Constants.WRAPPER) Wrapper<User> wrapper);

此时查看控制台打印结果:

在这里插入图片描述

@TableField(select = false)该注解对于自定义方法查询失效了,怎么做呢?加限定条件

 // 查询年龄大于xxx岁的
 List<User> userList = userMapper.mySelectList(Wrappers.<User>lambdaQuery()
          .gt(User::getAge,1).eq(User::getIsDeleted,0));

在这里插入图片描述

三、@TableField注解其他用法

Mybatis-plus使用注解 @TableField(exist = false) 注明非数据库字段属性

@TableField(exist = false) 

注解加载bean属性上,表示当前属性不是数据库的字段,但在项目中必须使用,这样在新增等使用bean的时候,mybatis-plus就会忽略这个,不会报错

Mybatis-Plus排除自定义字段不查询

需求原因

由于数据库表设计为一张为组表

一张为对应组下的参数表

在查询数据时想要在查询组表的同时吧对应组下的数据页同时查出来

所以在组实体类下增加了一个对应的参数来接受对应的组数据

在这里插入图片描述

错误截图

在这里插入图片描述

错误分析

根据查询语句来看

条件查询默认把所有字段都查出来了

但由于自定义的字段在数据库中不存在,所以报错

尝试

这里最大的问题就是如何把自定义字段排除掉,在网上搜了一圈,

最后才在Mybatis-plus的官方文档里发现

@TableFiled有一个exist属性,是用来定义字段是否为数据库表字段的。。。。

在这里插入图片描述

在这里插入图片描述

于是把该属性加上

在这里插入图片描述

重新运行

在这里插入图片描述

完美解决!

结论

有问题下次先看官方文档吧,以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家

相关文章

  • 使用Java获取linux和window序列号

    使用Java获取linux和window序列号

    这篇文章主要为大家详细介绍了如何使用Java获取Windows和Linux系统上的CPU序列号、磁盘、mac地址等信息,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-01-01
  • mybatis-plus主键策略生成失败的解决

    mybatis-plus主键策略生成失败的解决

    本文主要介绍了mybatis-plus主键策略生成失败的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • Springboot项目快速实现Aop功能

    Springboot项目快速实现Aop功能

    这篇文章主要介绍了Springboot项目如何快速实现Aop功能,对此方面感兴趣的小伙伴可以详细参考阅读本文,本文有一定的参考价值
    2023-03-03
  • Java 全方位讲解面向对象特点与使用

    Java 全方位讲解面向对象特点与使用

    面向对象开发方法将面向对象的思想应用于软件开发过程中,指导开发活动,是建立在“对象”概念基础上的方法学,简称OO( Object-Oriented)方法
    2022-04-04
  • Spring Boot 整合 Druid 并开启监控的操作方法

    Spring Boot 整合 Druid 并开启监控的操作方法

    本文介绍了如何在SpringBoot项目中引入和配置Druid数据库连接池,并开启其监控功能,通过添加依赖、配置数据源、开启监控、自定义配置以及访问监控页面,开发者可以有效提高数据库访问效率并监控连接池状态,感兴趣的朋友跟随小编一起看看吧
    2025-01-01
  • JAVA PDF操作之实现截取N页和多个PDF合并

    JAVA PDF操作之实现截取N页和多个PDF合并

    这篇文章主要为大家详细介绍了java关于PDF的一些操作,例如截取N页并生成新文件,转图片以及多个PDF合并,文中的示例代码讲解详细,感兴趣的可以了解下
    2025-01-01
  • Java实现自动压缩文件并加密的方法示例

    Java实现自动压缩文件并加密的方法示例

    这篇文章主要介绍了Java实现自动压缩文件并加密的方法,涉及java针对文件进行zip压缩并加密的相关操作技巧,需要的朋友可以参考下
    2018-01-01
  • 一文搞懂并学会使用SpringBoot的Actuator运行状态监控组件的详细教程

    一文搞懂并学会使用SpringBoot的Actuator运行状态监控组件的详细教程

    这篇文章主要介绍了一文搞懂并学会使用SpringBoot的Actuator运行状态监控组件,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 基于mybatis中test条件中单引号双引号的问题

    基于mybatis中test条件中单引号双引号的问题

    这篇文章主要介绍了基于mybatis中test条件中单引号双引号的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • java使用归并删除法删除二叉树中节点的方法

    java使用归并删除法删除二叉树中节点的方法

    这篇文章主要介绍了java使用归并删除法删除二叉树中节点的方法,实例分析了java二叉树算法的相关操作技巧,需要的朋友可以参考下
    2015-05-05

最新评论