把工单历史表中的数据,按照工单进行分类,每一批工单的数据放在同一个 key 中
/**
* 把工单历史表中的数据,按照工单进行分类,每一批工单的数据放在同一个key中
* 将对象列表按名称分类成 Map(分类名必与对象的某 get 方法的后的名一致<如:get(name) 实际是 get("ticketId")>
*
* @param list sql数据集合
* @param name HashMap<String,Object> 的某个 key ,实际上就是数据表中的某个字段
* @return Map<String, List < T>>
*/
public static Map<String, List<HashMap<String, Object>>> objListToMapClassificationByName(List<HashMap<String, Object>> list, String name) {
Map<String, List<HashMap<String, Object>>> resultMap = Maps.newHashMap();
for (HashMap<String, Object> obj : list) {
try {
String ticketId = obj.get(name).toString();
if (StringUtil.isEmpty(ticketId)) {
continue;
}
List<HashMap<String, Object>> tempList = null;
if (!resultMap.containsKey(ticketId)) {
tempList = new ArrayList<>();
} else {
tempList = resultMap.get(ticketId);
}
tempList.add(obj);
resultMap.put(ticketId, tempList);
} catch (Exception e) {
e.printStackTrace();
}
}
return resultMap;
}
案例:
//联表查询工单数据
List<HashMap<String, Object>> list = reportAllSqlMapper.selectAllSql(stringSql);
//拿到分类后的数据
Map<String, List<HashMap<String, Object>>> ticketHashMap = objListToMapClassificationByName(list, "ticketId");
上面的意思是把 ticketId 相同的数据都放到同一个 key 对应的 value 上。
如果是使用实体类,则直接使用下面这种方式即可
//联表查询工单数据
List<HistoryTypeBean> list = ticketIndicatorMapper.selectAllHistory(baseEntity);
//key = 工单id ,value = 相同的工单数据
Map<String, List<HistoryTypeBean>> map = list.stream().collect(Collectors.groupingBy(HistoryTypeBean::getTicketId));
@Data
public class HistoryTypeBean {
/**
* 工单id
*/
private String ticketId;
/**
* slaId
*/
private String slaId;
/**
* article_id 当 history_type_id 状态为 2,用 articleId 去 article 表根据 is_visible_for_customer 判断是内部还是外部备注
*/
private String articleId;
/**
* 工单历史操作类型
*/
private String historyTypeId;
/**
* 工单历史操作状态类型
*/
private String ticketHistoryStateId;
/**
* 工单状态类型表,工单操作状态
*/
private String ticketStateTypeId;
/**
* 日历表日历id
*/
private String calendarId;
/**
* 工单历史表创建时间
*/
private String createTime;
/**
* 工单历史表queue_id
*/
private String historyQueueId;
}
把工单历史表中的数据,按照工单进行分类,每一批工单的数据放在同一个 key 中的更多相关文章
- Activiti系列:是否可以让某些流程的信息写到历史表,而另外一些不写?
一.起因 打算使用activiti的定时启动事件来定时启动流程,然后再在该流程中针对每个用户启动另外一个流程实例来计算每个用户的实时账单,系统的用户数一般是1000~2000(此处假设是200 ...
- oracle 中从一个历史表中查询最新日期数据插入到另一个表中语句
先从历史表中查询最新的一个语句: select t.id from ( select r.*, row_number() over(partition by r.分组字段 order by r.排序时 ...
- 迁移数据到历史表SQL(转)
有时工作需要需要把当前表的数据,移到历史表中,而历史表基本是以时间(年)为后缀来命名历史表的,如 A_2011,A_2012,在移数据时,要按数据的时间,移到不同的表中,且由于如果数据有同步.一次处理 ...
- ADO.NET事务处理,初始回调函数,多张表的数据在同一个DataGridView中展示
执行ADO.NET事务包含四个步骤,接下来以Transaction对象为例介绍. (1)调用SQLConnection对象的BeginTransaction()方法,创建一个SQLTransactio ...
- JavaScript 客户端JavaScript之Document对象中的表单和表单元素
Form对象 代表一个HTML表单(document可以有多个表单元素) 表单访问 document.form[document.forms.length-1] 访问表单元素 document.for ...
- MySQL存储过程-->通过游标遍历和异常处理迁移数据到历史表
-- 大表数据迁移,每天凌晨1点到5点执行,执行间隔时间10分钟,迁移旧数据到历史表. DELIMITER $$ USE `dbx`$$ DROP PROCEDURE IF EXISTS `pro_x ...
- kylin的clube合并后清理hbase中产生的相关历史表
kylin的clube合并后清理hbase中产生的相关历史表 kylin 的clube 历史的每次构建,都会产生一个hbase的表:虽然可以设置按照一定策略合并,但是合并后hbase 历史表不会被自动 ...
- Oracle数据库--解决单张表中数据量巨大(大数据、数据量上百万级别,后查询,更新数据等耗时剧增)
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/QQ578473688/article/details/54561397 思路1:采用备份表 备份表中 ...
- SQLSERVER 数据调度示例,调度数据到中间表或者历史表
USE [MeiDongPay_Test] GO /****** Object: StoredProcedure [dbo].[Job_BatchTransferOrderToMidst] Scrip ...
- ajaxSubmit 页面生成的html 中含有表单提交表单方式
$("#form_title").ajaxSubmit({ //页面生成的html 中含有表单提交表单方式 dataType: "json", success ...
随机推荐
- PerfView专题 (第十四篇): 洞察那些 C# 代码中的短命线程
一:背景 1. 讲故事 这篇文章源自于分析一些疑难dump的思考而产生的灵感,在dump分析中经常要寻找的一个答案就是如何找到死亡线程的生前都做了一些什么?参考如下输出: 0:001> !t T ...
- Lora简介
断断续续接触lora已经有几年时间了,一直用lora来做点对点的传输,近来有朋友想通过Lora来做广播群发和群收管理,想通过低成本方式实现,sx1302几百的银子,成本有点高,尝试通过sx1278/L ...
- jenkins打包报错的排查思路与解决
背景 废话少说, 在新建一个jenkins流水线时, 碰到了打包死活无法成功的问题, 相关配置如下图 运行后最后的日志如图 定位问题 通过查看日志, 发现报错的模块是构建后执行shell的时候, 但是 ...
- [Python]队列基础
关于队列 基本的队列是一种先进先出的数据结构. 一般的队列基本操作如下: create:创建空队列 add:将新数据加入队列的末尾.返回新队列. delete:删除队列头部的数据,返回新队列. fro ...
- 从浅入深了解.NET Core MVC 2.x全面教程【第二章】
二.Logging 1.诊断中间件 命名空间:Microsoft.AspNetCore.Diagnostics 报告信息并处理异常 2.诊断中间件 UseDeveloperExceptionPage: ...
- 使用kube-bench检测Kubernetes集群安全
目录 一.系统环境 二.前言 三.CIS (Center for Internet Security)简介 四.什么是Kube-Bench? 五.使用kube-bench检测不安全的设置 5.1 手动 ...
- 解决git出现fatal: detected dubious ownership in repository at XXXXX的错误
在window环境下,使用git命令时报错fatal: detected dubious ownership in repository at XXXXXX,图片如下 解决方法如下 添加一行代码 gi ...
- SpringBoot 测试实践 - 2:单元测试与集成测试
单元测试 vs. 集成测试 只编写单测,无法测试方法之间的集成情况,而且某些需求可能会修改多个方法,这可能会影响方法对应的单测,涉及到大量的相关单测的修改,这样的维护成本很高 可以把重心放在完善集成测 ...
- paging组件的用法和意义
一.Paging组件的意义 分页加载是在应用程序开发过程中十分常见的需求,我们经常需要以列表的方式加载大量的数据,这些数据通常来自网络或本地数据库.然而,如果一次性将所有数据全部加载出来,必然会消耗大 ...
- Python 基础面试第四弹
1. Python中常用的库有哪些,作用分别是什么 requests: requests 是一个用于发送 HTTP 请求的库,它提供了简单而优雅的 API,可以轻松地发送 GET.POST.PUT.D ...