Mybatis Plus Wrapper查询某几列的方法实现

 更新时间:2024年10月11日 10:22:17   作者:木头左  
MybatisPlus中,使用Wrapper的select和notSelect方法可以精确控制查询的字段,本文就来介绍一下Mybatis Plus Wrapper查询某几列的方法实现,感兴趣的可以了解一下

在Mybatis Plus中,经常需要根据条件进行查询,但是有时候并不需要查询所有的字段,只需要查询某几列。这时候可以使用Wrapper的select方法来实现。下面我将详细介绍如何使用Wrapper来查询某几列,不查询某几列。

1. 基本用法

需要创建一个实体类,例如User,然后创建一个对应的Mapper接口,例如UserMapper。接着,可以在Service层或者Controller层使用Wrapper来进行查询。

@Service
public class UserService {
    @Autowired
    private UserMapper userMapper;

    public List<User> selectColumns(Wrapper<User> wrapper) {
        return userMapper.selectList(wrapper);
    }
}

在上面的代码中,定义了一个selectColumns方法,该方法接收一个Wrapper参数,然后调用userMapper的selectList方法进行查询。

2. 查询某几列

如果想要查询User实体中的name和age字段,可以这样写:

Wrapper<User> wrapper = new QueryWrapper<>();
wrapper.select("name", "age");
List<User> users = userService.selectColumns(wrapper);

在上面的代码中,创建了一个QueryWrapper对象,然后调用select方法传入要查询的字段名,最后调用userService的selectColumns方法进行查询。

3. 不查询某几列

如果不想查询User实体中的id字段,可以这样写:

Wrapper<User> wrapper = new QueryWrapper<>();
wrapper.select(User.class, i->!i.getColumn().equals("id"));
List<User> users = userService.selectColumns(wrapper);

在上面的代码中,创建了一个QueryWrapper对象,然后调用select方法传入要查询的字段名,接着调用notSelect方法传入不想查询的字段名,最后调用userService的selectColumns方法进行查询。

4. mybatis-plus只查询部分字段的两种方法

方法1:只需要查询出name和phone两个字段:使用queryWrapper的select()方法指定要查询的字段

@Test
  public void selectByWrapper1() {
  QueryWrapper<User> queryWrapper = new QueryWrapper<>();
  queryWrapper.select("name", "phone").eq("age",25);
  List<User> users = userMapper.selectList(queryWrapper);
  users.forEach(System.out::println);
 }

方法2:查询出除age和address外其它所有字段的数据:同样使用queryWrapper的select()方法

 @Test
 public void selectByWrapper2() {
 QueryWrapper<User> queryWrapper = new QueryWrapper<>();
 queryWrapper.select(User.class, info -> !info.getColumn().equals("age")
 && !info.getColumn().equals("address")).eq("name","jack");
 List<User> users = userMapper.selectList(queryWrapper);
 users.forEach(System.out::println);
}

到此这篇关于Mybatis Plus Wrapper查询某几列的方法实现的文章就介绍到这了,更多相关Mybatis Plus Wrapper查询某几列内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mybatis-Plus读写Mysql的Json字段的操作代码

    Mybatis-Plus读写Mysql的Json字段的操作代码

    这篇文章主要介绍了Mybatis-Plus读写Mysql的Json字段的操作代码,文中通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • springmvc中下载中文文件名称为下划线的解决方案

    springmvc中下载中文文件名称为下划线的解决方案

    这篇文章主要介绍了springmvc中下载中文文件名称为下划线的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • Java中你绝对没用过的一个关键字Record的使用

    Java中你绝对没用过的一个关键字Record的使用

    这篇文章主要给大家介绍一个 Java 中的一个关键字 Record,那 Record 关键字跟不可变类有什么关系呢?看完今天的文章你就知道了,快跟随小编一起学习一下吧
    2022-11-11
  • Java魔法值处理的四种方式

    Java魔法值处理的四种方式

    这篇文章主要介绍了Java魔法值处理的四种方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • 一文掌握Spring Boot 日志文件

    一文掌握Spring Boot 日志文件

    日志是程序的重要组成部分,日志对于我们来说,最主要的用途就是排除和定位问题,这篇文章主要介绍了Spring Boot 日志文件,需要的朋友可以参考下
    2023-03-03
  • spring boot项目fat jar瘦身的实现

    spring boot项目fat jar瘦身的实现

    这篇文章主要介绍了spring boot项目fat jar瘦身的实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • java并发编程_线程池的使用方法(详解)

    java并发编程_线程池的使用方法(详解)

    下面小编就为大家带来一篇java并发编程_线程池的使用方法(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 性能调优之java服务器容器调优详解

    性能调优之java服务器容器调优详解

    这篇文章主要介绍了java服务器容器调优,如果接口响应时间超过了既定数据,项目支撑不了这么大的请求,就需要对项目以及项目接口进行数据库、容器、缓存等方面的调优,文章中有详细的代码示例,需要的朋友可以参考一下
    2023-04-04
  • 深入理解Spring注解@Async解决异步调用问题

    深入理解Spring注解@Async解决异步调用问题

    这篇文章主要介绍了深入理解Spring注解@Async解决异步调用问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Java如何调用Matlab程序

    Java如何调用Matlab程序

    这篇文章主要介绍了Java如何调用Matlab程序的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09

最新评论