1. /**
    * 把工单历史表中的数据,按照工单进行分类,每一批工单的数据放在同一个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;
    }

  1. 案例:
  1. //联表查询工单数据
    List<HashMap<String, Object>> list = reportAllSqlMapper.selectAllSql(stringSql);

    //拿到分类后的数据
    Map<String, List<HashMap<String, Object>>> ticketHashMap = objListToMapClassificationByName(list, "ticketId");
  1. 上面的意思是把 ticketId 相同的数据都放到同一个 key 对应的 value 上。


  1. 如果是使用实体类,则直接使用下面这种方式即可
  1. //联表查询工单数据
    List<HistoryTypeBean> list = ticketIndicatorMapper.selectAllHistory(baseEntity);
  1. //key = 工单id ,value = 相同的工单数据
  1. Map<String, List<HistoryTypeBean>> map = list.stream().collect(Collectors.groupingBy(HistoryTypeBean::getTicketId));
  1.  

  1.  
  1. @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;

    }
  1.  

把工单历史表中的数据,按照工单进行分类,每一批工单的数据放在同一个 key 中的更多相关文章

  1. Activiti系列:是否可以让某些流程的信息写到历史表,而另外一些不写?

    一.起因     打算使用activiti的定时启动事件来定时启动流程,然后再在该流程中针对每个用户启动另外一个流程实例来计算每个用户的实时账单,系统的用户数一般是1000~2000(此处假设是200 ...

  2. oracle 中从一个历史表中查询最新日期数据插入到另一个表中语句

    先从历史表中查询最新的一个语句: select t.id from ( select r.*, row_number() over(partition by r.分组字段 order by r.排序时 ...

  3. 迁移数据到历史表SQL(转)

    有时工作需要需要把当前表的数据,移到历史表中,而历史表基本是以时间(年)为后缀来命名历史表的,如 A_2011,A_2012,在移数据时,要按数据的时间,移到不同的表中,且由于如果数据有同步.一次处理 ...

  4. ADO.NET事务处理,初始回调函数,多张表的数据在同一个DataGridView中展示

    执行ADO.NET事务包含四个步骤,接下来以Transaction对象为例介绍. (1)调用SQLConnection对象的BeginTransaction()方法,创建一个SQLTransactio ...

  5. JavaScript 客户端JavaScript之Document对象中的表单和表单元素

    Form对象 代表一个HTML表单(document可以有多个表单元素) 表单访问 document.form[document.forms.length-1] 访问表单元素 document.for ...

  6. MySQL存储过程-->通过游标遍历和异常处理迁移数据到历史表

    -- 大表数据迁移,每天凌晨1点到5点执行,执行间隔时间10分钟,迁移旧数据到历史表. DELIMITER $$ USE `dbx`$$ DROP PROCEDURE IF EXISTS `pro_x ...

  7. kylin的clube合并后清理hbase中产生的相关历史表

    kylin的clube合并后清理hbase中产生的相关历史表 kylin 的clube 历史的每次构建,都会产生一个hbase的表:虽然可以设置按照一定策略合并,但是合并后hbase 历史表不会被自动 ...

  8. Oracle数据库--解决单张表中数据量巨大(大数据、数据量上百万级别,后查询,更新数据等耗时剧增)

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/QQ578473688/article/details/54561397 思路1:采用备份表 备份表中 ...

  9. SQLSERVER 数据调度示例,调度数据到中间表或者历史表

    USE [MeiDongPay_Test] GO /****** Object: StoredProcedure [dbo].[Job_BatchTransferOrderToMidst] Scrip ...

  10. ajaxSubmit 页面生成的html 中含有表单提交表单方式

    $("#form_title").ajaxSubmit({ //页面生成的html 中含有表单提交表单方式 dataType: "json", success ...

随机推荐

  1. Java计算日期之间相差时间和解决浮点类型精度过长

    计算日期之间相差 此处相差计算以分钟为单位,自行可根据业务场景更改 /** * 测试时间相差分钟 */ @Test public void getTime() { SimpleDateFormat s ...

  2. 2021-8-2 Mysql个人练习题

    创建学生表 CREATE TABLE student( id int, uname VARCHAR(20), chinese FLOAT, english FLOAT, math FLOAT ); I ...

  3. React报错:This is probably not a problem with npm. There is likely additional logging output above.

    解决方案 删除node_modules和package-lock.json,之后运行npm cache clear --force,重新安装模块npm install,另外要注意 npm 5.0版本之 ...

  4. nuitka 将程序编译为单个exe

    原文链接:https://github.com/Nuitka/Nuitka 在Windows上,有两种模式,一种是将其复制到您公司指定的AppData,也将其用作缓存,另一种是在临时目录中进行.您需要 ...

  5. 使用 python 快速搭建http服务

    python -m SimpleHTTPServer 8888 使用上面的命令可以把当前目录发布到8888端口. 直接浏览器访问 但是这条命令是当前运行的,不是后台运行的,也就是说如果Ctrl + C ...

  6. 【笔记】- 【美团1万台 Hadoop 集群 YARN 的调优之路】

    原文:美团1万台 Hadoop 集群 YARN 的调优之路 背景 架构 YARN架构 资源抽象 YARN调度架构 资源抽象 调度流程 作业的组织方式 核心调度流程 指标 业务指标:有效调度 系统性能指 ...

  7. IDA函数特征识别自动签名

    IDA函数特征识别自动签名 Vc6编译的有些无法识别一些库里面的函数 测试代码 #include <stdio.h> int main() { printf("123456\n& ...

  8. 【技术积累】Vue.js中的CSS过渡【一】

    CSS过渡是什么 在Vue中,可以使用<transition>组件来实现CSS过渡效果.CSS过渡是指在元素的状态发生改变时,通过添加或移除CSS类来实现平滑的过渡效果. <tran ...

  9. Qt安卓开发经验技巧总结V202308

    01:01-05 pro中引入安卓拓展模块 QT += androidextras . pro中指定安卓打包目录 ANDROID_PACKAGE_SOURCE_DIR = $$PWD/android ...

  10. DDD实践:实现基于快照机制的变更追踪

    王有志,一个分享硬核Java技术的互金摸鱼侠 加入Java人的提桶跑路群:共同富裕的Java人 去年我们在重构项目中落地了DDD,当时花了点时间研究了下阿里巴巴大淘宝技术发布的<阿里技术专家详解 ...