Mybatis-plus listObjs()

1. ​listObjs() 的作用​

listObjs() 是 MyBatis-Plus 提供的一个特殊查询方法,用于:

  • ​只查询单列数据​ ​(比如只查 user_id 这一列)

  • ​自动将结果转换为指定类型​ ​(如 LongString 等)

  • queryWrapper ​:已经设置了 select(Follow::getUserId),表示只查 user_id

  • obj -> (Long) obj ​:将查询到的 user_id 值强制转换为 Long 类型

我来详细解释 listObjs() 的用法,并用最简单的方式教你如何使用它。


1. ​listObjs() 的作用​

listObjs() 是 MyBatis-Plus 提供的一个特殊查询方法,用于:

  • ​只查询单列数据​ (比如只查 user_id 这一列)
  • ​自动将结果转换为指定类型​ (如 LongString 等)

2. ​​你的代码解析​

kotlin 复制代码
List<Long> followerIds = followService.listObjs(
    queryWrapper,      // 查询条件
    obj -> (Long) obj  // 结果转换函数(将Object转为Long)
);
  • queryWrapper :已经设置了 select(Follow::getUserId),表示只查 user_id
  • obj -> (Long) obj :将查询到的 user_id 值强制转换为 Long 类型

3. ​​分步拆解(完全等价写法)​

如果你觉得 Lambda 表达式难以理解,可以拆解成这样:

ini 复制代码
java
复制
// 1. 执行查询,获取Object类型的结果列表
List<Object> rawResults = followService.listObjs(queryWrapper);

// 2. 手动转换为Long类型
List<Long> followerIds = new ArrayList<>();
for (Object obj : rawResults) {
    followerIds.add((Long) obj);
}

4. ​​实际场景示例​

假设有一个 follow 表,结构如下:

id user_id follow_user_id
1 100 200
2 101 200

你想查询 follow_user_id = 200 的所有粉丝的 user_id

(1) 完整代码
ini 复制代码
java
复制
// 构建查询条件
LambdaQueryWrapper<Follow> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(Follow::getFollowUserId, 200)  // WHERE follow_user_id = 200
           .select(Follow::getUserId);        // 只查 user_id 列

// 执行查询
List<Long> followerIds = followService.listObjs(queryWrapper, obj -> (Long) obj);

// 结果:followerIds = [100, 101]
(2) 如果不用 Lambda
ini 复制代码
java
复制
QueryWrapper<Follow> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("follow_user_id", 200)
           .select("user_id");  // 直接写列名

List<Long> followerIds = followService.listObjs(queryWrapper, obj -> (Long) obj);

5. ​​常见问题解答​

Q1: 为什么不能直接用 list()
  • list() 会返回 ​完整实体对象列表​ (所有字段),但你只需要 user_id 这一列,用 listObjs() 更高效。
Q2: 如果查询多列怎么办?
  • listObjs() 只能查单列,多列查询请用 listMaps()

    javascript 复制代码
    queryWrapper.select("user_id", "create_time");
    List<Map<String, Object>> result = followService.listMaps(queryWrapper);

    最推荐写法

    perl 复制代码
    List<Long> followerIds = followService.listObjs(
        Wrapper.<Follow>query()
            .eq("follow_user_id",200)
            .select("user_id"),
        obj -> (Long) obj
    );
相关推荐
小王不爱笑1321 天前
MyBatis 执行流程源码级深度解析:从 Mapper 接口到 SQL 执行的全链路逻辑
数据库·sql·mybatis
弹简特1 天前
【JavaEE18-后端部分】 MyBatis 入门第二篇:使用注解完成增删改查(含有参数传递底层原理)
spring boot·mybatis
小王不爱笑1321 天前
SpringBoot 自动装配深度解析:从底层原理到自定义 starter 实战(含源码断点调试)
java·spring boot·mybatis
青槿吖1 天前
SpringMVC通关秘籍(下):日期转换器、拦截器与文件上传的奇幻冒险
java·开发语言·数据库·sql·mybatis·状态模式
LSL666_1 天前
BaseMapper——新增和删除
java·开发语言·mybatis·mybatisplus
摇滚侠1 天前
IDEA 开发,Mybatis 中,@Insert 注解如何提示出列名
java·intellij-idea·mybatis
小王不爱笑1321 天前
MyBatis-Plus 核心知识点
mybatis
码界奇点1 天前
基于Spring MVC和MyBatis的妖气山视频管理系统设计与实现
java·spring·毕业设计·mvc·mybatis·源代码管理
indexsunny1 天前
互联网大厂Java面试实战:从Spring Boot到微服务与Kafka的深度探讨
java·spring boot·junit·kafka·mybatis·hibernate·microservices
LSL666_1 天前
5 MySQL驱动类选择与数据库连接 URL 时区配置
数据库·mysql·mybatis·mybatisplus