Springboot根据mapper名称动态获取表数据(如ID)

前言

例如:开发过程中,有全选跨页的需求(点击列表页上的全选会把所有页面的数据都勾选上),需要返回全部id作为标志。

故需要一个接口返回表的所有id对象供前端使用,为此,写了个通用的接口。只需提供注册在Spring中的mapper名称即可。


具体代码

java 复制代码
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.fas.fasservice.exception.ServiceException;
import com.fas.fasservice.util.StringUtil;
import lombok.RequiredArgsConstructor;
import org.springframework.context.ApplicationContext;
import org.springframework.stereotype.Service;

import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;

@Service
@RequiredArgsConstructor()
public class DynamicQueryService {

    private final ApplicationContext applicationContext;

    /**
     * 根据类型动态获取对应的 Mapper 并执行查询操作
     *
     * @param mapperName Mapper 的名称,例如 "studentMapper" 或 "scoreMapper"
     */
    @SuppressWarnings("all")
    public <T> List<String> getIdsByMapperName(String mapperName) {

        if (StringUtil.isNull(mapperName)) {
            throw new ServiceException("参数不能为空");
        }
        BaseMapper<T> mapper;
        try {
            mapper = (BaseMapper<T>) applicationContext.getBean(mapperName);
        } catch (Exception e) {
            throw new ServiceException("无对应的mapper对象");
        }

        // 构造查询条件
        QueryWrapper<T> queryWrapper = new QueryWrapper<>();
        queryWrapper.select("id");
        queryWrapper.eq("delete_flag", "0");

        List<T> ts = mapper.selectList(queryWrapper);
        return processList(ts);
    }

    public static <T> List<String> processList(List<T> ts) {
        List<String> result = new ArrayList<>();
        if (ts == null || ts.isEmpty()) {
            return result;
        }
        // 获取第一个元素的类信息
        Class<?> clazz = ts.get(0).getClass();
        try {
            // 获取getId方法
            Method getIdMethod = clazz.getMethod("getId");
            for (T t : ts) {
                Object id = getIdMethod.invoke(t);
                result.add(String.valueOf(id));
            }
        } catch (Exception e) {
            throw new ServiceException("调用getId方法失败");
        }
        return result;
    }
}

总结

可以根据提供的方法去做定制,无非就是加判断加条件,以达到自己的目的。

相关推荐
AntBlack18 小时前
上下求索,2025年我用AI写了哪些东西
后端·ai编程·年终总结
鸡蛋豆腐仙子18 小时前
redis及实现分布式锁的原理
java·redis·分布式·学习·缓存
好家伙VCC18 小时前
# 发散创新:基于Solidity的DeFi协议设计与实现——从原理到实战代码解析在区块链世界中,**DeFi(去中心化金
java·python·去中心化·区块链
H Corey18 小时前
Java字符串操作全解析
java·开发语言·学习·intellij-idea
Aric_Jones18 小时前
博客音乐播放器实现全解析
java·运维·数据库·人工智能·docker·容器·eclipse
墨染青竹梦悠然18 小时前
基于SpringBoot + vue的农产品销售系统(华夏鲜仓)
vue.js·spring boot·python·django·毕业设计·毕设
2501_9419820518 小时前
Python开发:实现企微外部群消息关键词监控
java·服务器·数据库
brucelee18618 小时前
Java 开发AWS Lambda 实战指南(SAM CLI + IntelliJ)
java·开发语言
码云数智-大飞18 小时前
Nginx负载均衡四大核心算法深度解析:原理、配置与选型实战
java
消失的旧时光-194318 小时前
第二十一课:系统是怎么一步步拆坏的?——单体到模块化实践(完整工程版)
java·spring boot·后端·架构