首页 > 编程语言 >Java 多表联查

Java 多表联查

时间:2023-10-26 14:24:28浏览次数:33  
标签:Java String get schemeInfo private deptMap getDepId 多表 联查

Java多表联查

前提:由于我当前页面显示的数据 是在其他两个表中 只有ID可以使用

1、分别对两个表进行操作,将List转为Map对象

//查询项目表
List<BudgetProjectInfo> budgetProjectInfoList = budgetProjectInfoService.list();
Map<String,BudgetProjectInfo> schemMap = budgetProjectInfoList.stream().collect(Collectors.toMap(BudgetProjectInfo::getId,Function.identity()));
//查询部门表
List<ComDept> comDeptList = comDeptServiceImpl.list();
Map<String,ComDept> deptMap = comDeptList.stream().collect(Collectors.toMap(ComDept::getId, Function.identity()));

2、设置页面所需要的数据,筛选条件

QueryWrapper<BudgetSchemeInfo> schemeQuery = Wrappers.query();
schemeQuery.eq(StringUtils.isNotEmpty(schemeInfo.getDeclareYear()), BudgetSchemeInfoUtil.COLUMN_DECLARE_YEAR,schemeInfo.getDeclareYear())
      .eq(StringUtils.isNotEmpty(schemeInfo.getDepId()),BudgetSchemeInfoUtil.COLUMN_DEP_ID,schemeInfo.getDepId())
      .eq(StringUtils.isNotEmpty(schemeInfo.getDataSource()),BudgetSchemeInfoUtil.COLUMN_DATA_SOURCE,schemeInfo.getDataSource())
      .eq(StringUtils.isNotEmpty(schemeInfo.getSchoolCode()),BudgetSchemeInfoUtil.COLUMN_SCHOOL_CODE,schemeInfo.getSchoolCode());
Page<BudgetSchemeInfo> page = new Page<>(schemeInfo.getPageCurrent(), schemeInfo.getPageSize());
IPage<BudgetSchemeInfo> budgetSchemeInfoIPage = this.page(page, schemeQuery);

3、写VO,例如(里面写的是自己数据库没有,要调用其他数据库的数据的值,记得导入Get和Set,此处略)

/** 项目编号**/
private String proCode;
/** 项目名称**/
private String proName;
/** 部门编号**/
private String deptNum;
/** 部门名称**/
private String deptName;
/** 项目状态**/
private String proStatus;

4、将实体对象转换为VO

List<BudgetSchemeVO> fmsAtInfoVOList = ObjectParamCopyUtil.copyList(budgetSchemeInfoIPage.getRecords(),BudgetSchemeVO.class);

5、循环获取数据(根据ProId找项目表中数据,根据DepId找部门表中数据)

for (BudgetSchemeVO b:fmsAtInfoVOList){
   b.setProCode(schemMap.get(b.getProId()).getProNo());
   b.setProName(schemMap.get(b.getProId()).getProName());
   if(StringUtils.isNotEmpty(deptMap.get(b.getDepId()).getDeptNum())) {
      b.setDeptNum(deptMap.get(b.getDepId()).getDeptNum());
   }
   //b.setDeptNum(deptMap.get(b.getDepId()).getDeptNum());
   b.setDeptName(deptMap.get(b.getDepId()).getDeptName());
   b.setProStatus(schemMap.get(b.getProId()).getStatus());

}

6、返回数据

return ResultJsonUtil.returnResult(ResultEnum.SUCCESS, VoUtilFactory.convertToVoPage(fmsAtInfoVOList,budgetSchemeInfoIPage));

标签:Java,String,get,schemeInfo,private,deptMap,getDepId,多表,联查
From: https://www.cnblogs.com/nuomibaibai/p/17789294.html

相关文章

  • mysql表关联查询-索引失效问题
    问题:两张关联表索引字段的字符集不一致导致索引失效。解决方案:先用EXPLAIN检查关联字段是否使用了索引,查看两张表的字段不一致导致将两张表索引字段的字符集发现字符集不一致,重新将字符集统一为utf8mb4。 ......
  • Java中 List和数组之间的常见转换方法
    List转数组1、使用for循环//要转换的list集合List<String>list=newArrayList<>();list.add("aa");list.add("bb");list.add("cc");//初始化需要得到的数组String[]array=newString[list.size()];//使用fo......
  • Java中List拷贝至新的List
    Java中List拷贝至新的List在Java中,如果你想拷贝一个List对象到一个新的List对象,并且修改原来的List不影响新的List中的内容,有几种方法可以实现:1.使用构造函数可以使用List的构造函数,传递原始List作为参数来创建一个新的List对象。这样做会创建一个新的List对象,两个List对象互相......
  • Java面试笔记
    Java面试笔记Java面试笔记第一章:Java基础知识1.1Java程序初始化顺序Java程序初始化一般遵循以下三个原则(优先级依次递减)静态对象(变量)​优先于​非静态对象初始化静态对象初始化一次非静态对象可能初始化多次父类优先于子类初始化按照成员变量定义顺序进行初始化即使变......
  • 车险自助理赔系统 JAVA开源项目 毕业设计
    https://gf.bilibili.com/item/detail/1104012029为了帮助小白入门Java,博主录制了本项目配套的《项目手把手启动教程》,希望能给同学们带来帮助。一、摘要基于Vue+SpringBoot+MySQL的车险自助理赔系统包含车辆管理模块、车险理赔模块、理赔审核模块,还包含系统自带的用户管理、部门......
  • 森林火灾预警系统 JAVA开源项目 毕业设计
    https://gf.bilibili.com/item/detail/1104013029为了帮助小白入门Java,博主录制了本项目配套的《项目手把手启动教程》,希望能给同学们带来帮助。一、摘要基于websocket+Vue+SpringBoot+MySQL的森林火灾预警系统,包含园区数据模块、温度传感器模块、烟雾传感器模块、园区监控模块、......
  • 高校学院网站 JAVA开源项目 毕业设计
    https://gf.bilibili.com/item/detail/1104015029为了帮助小白入门Java,博主录制了本项目配套的《项目手把手启动教程》,希望能给同学们带来帮助。一、摘要基于Vue2/Vue3+SpringBoot+MySQL的高校学院网站包含学院概况模块、学院院系模块、党建园地模块、竞赛报名模块、教育教学模块......
  • Java 创建线程的方法
    目录继承Thread类实现Runnable接口实现Callable接口,并结合Future实现通过线程池创建线程方式一:Runnable方式二:CompletableFutureJava中创建线程有四种方式,分别是:继承Thread类首先定义一个类来继承Thread类,重写run方法。然后创建这个子类对象,并调用start......
  • JAVASCRIPT 上传文件的几种方式
    方法1:使用ajax,通过formdata传参//注意:FormData只兼容到IE10varformData=newFormData();varfile=$('.import-file-btn').get(0).files[0];formData.append('file',file);formData.append('id',id);formData.append('name',name)......
  • Java 练习题03 String类
    1. 编写一个程序,将下面的一段文本中的各个单词的字母顺序翻转, "Tobeornottobe",将变成"oTebrotonoteb."。importjava.util.Arrays;publicclassTest08{publicstaticvoidmain(String[]args){Strings="Tobeornottobe";//1.将字符串切......