接口返回动态列名及动态列数据结构

news2024/11/17 16:13:33

接口返回动态列名及动态列数据结构代码方案

在开发过程中,有时我们需要处理动态表头和动态列数据的问题。特别是在一些数据统计或报表类需求中,列名和数据都可能随着时间或条件发生变化。本文将结合实际代码和表格展示,详细说明如何在接口中实现返回动态列名和动态列数据。

一、问题描述

假设我们在处理房屋供应数据时,不仅需要返回基础的列信息(如房型、面积、均价等),还需要动态地返回不同日期下的供应套数,如下图所示:

在这里插入图片描述

从图中可以看出,日期列是动态生成的,且供应套数也是根据不同日期进行展示。为了实现这种需求,我们需要设计一种灵活的接口响应结构。

二、设计思路

  1. 定义实体类:我们需要一个实体类来承载返回的数据结构,包括房屋类型、房型、面积、均价、供应总套数等基本字段,同时还要处理动态列数据。

  2. 动态列解析:通过将数据库中的某个字段(如 val 字段)存储的聚合值解析成多个动态列,这些列代表不同的日期,并且日期下的值表示供应套数。

  3. 动态列名存储:使用 LinkedHashSet 来保证列名的唯一性和有序性,同时确保列名是动态生成的,且按照日期排序。

三、代码实现

1. 实体类设计

首先,定义一个实体类 SupplyFeaturesVo 来承载数据。为了简化 val 字段的处理,我们在实体类中对其做了序列化忽略的标注。

@Data
public class SupplyFeaturesVo implements Serializable {

    /**
     * 房屋类型
     */
    private String houseType;

    /**
     * 房型
     */
    private String roomType;

    /**
     * 面积
     */
    private String acg;

    /**
     * 均价
     */
    private String avg;

    /**
     * 供应(成交)总套数
     */
    private String num;

    /**
     * 聚合值   2022-03-27@10,2022-03-26@4
     */
    @JSONField(serialize = false)
    private String val;
}

2. 处理逻辑

接下来,通过后端代码处理数据库返回的数据。我们要解析 val 字段,将其转化为动态列,并计算总供应套数。

public ItemResp<SupplyFeaturesResp> supplyFeaturesAll(SupplyFeaturesReq req) {

    //房屋类型条件处理
    req.setHouseType(SqlUtil.newHouseTypeConditionToSql(req.getHouseType(), "a.housetype"));

    // 获取数据
    List<SupplyFeaturesVo> resultList = newHouseMarkerMapper.supplyFeaturesAll(req);

    if (CollUtil.isEmpty(resultList)) {
        return new ItemResp<>(ApiSaasCodeEnums.NoData);
    }

    // 保存动态数据
    List<Map<String, Object>> list = new ArrayList<>();
    LinkedHashSet<String> dynamicDisplayFields = new LinkedHashSet<>();

    resultList.forEach(t -> {
        Map<String, Object> listBean = MapUtils.entityToMap(t);
        String val = t.getVal();
        Integer supplyNum = 0;

        if (StrUtil.isNotBlank(val)) {
            //val : 2022-03-27@10,2022-03-26@4
            String[] valArrays = val.split(",");
            for (String bean : valArrays) {
                String[] data = bean.split("@");
                String dateTime = data[0];
                String num = data[1];
                // 动态添加列名
                dynamicDisplayFields.add(dateTime);
                // 动态添加列值
                listBean.put(dateTime, data[1]);
                // 计算供应总数
                supplyNum = supplyNum + Convert.toInt(num, 0);
            }
        }

        // 设置供应总套数
        listBean.put("num", supplyNum);
        list.add(listBean);
    });

    // 对动态列名进行排序
    List<String> dynamicDisplayFieldList = dynamicDisplayFields.stream().sorted(Comparator.comparing(String::valueOf)).collect(Collectors.toList());

    // 返回结果
    SupplyFeaturesResp result = new SupplyFeaturesResp();
    result.setSets(new SupplyFeaturesResp.SupplyFeaturesData(list.size(), list));
    result.setDynamicDisplayFields(dynamicDisplayFieldList);

    return new ItemResp<>(result);
}

3. 核心解析逻辑

在代码中,val 字段存储的是聚合值(如 2022-03-27@10,2022-03-26@4),我们通过 split 方法将其解析为动态的列名(日期)和列值(供应数量)。随后,将这些动态列存储到 listBean 对象中,并动态生成列名列表用于前端展示。

4. 动态列名和数据结构

返回的响应数据结构将包含两个部分:

  • 动态列名:由不同日期组成的列名集合,用于动态展示。
  • 数据集合:每一行包含房型、面积、均价、供应总套数,以及多个动态列(供应日期和对应的供应数量)。

四、总结

本文通过具体的代码示例展示了如何在接口中返回动态列名及动态列数据结构。在处理诸如报表、统计类数据时,动态列的生成和处理是一项常见需求,掌握这种处理方式能够让我们的代码更加灵活,满足不断变化的业务需求。

希望这篇文章对你在处理动态列数据时有所帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2169590.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微信阅读网站小程序+ssm论文ppt源码调试讲解

第2章 开发环境与技术 微信阅读网站小程序的编码实现需要搭建一定的环境和使用相应的技术&#xff0c;接下来的内容就是对微信阅读网站小程序用到的技术和工具进行介绍。 2.1 MYSQL数据库 本课题所开发的应用程序在数据操作方面是不可预知的&#xff0c;是经常变动的&#xf…

Linux中的tr命令详解

1&#xff0c; 将小写字母转换为大写字母&#xff1a; echo "hello" | tr a-z A-Z但是限定字母的范围的话&#xff0c;是什么输出你们知道吗&#xff1f; echo "hello" | tr a-l A-L2&#xff0c;删除特定字符&#xff1a; 比如&#xff0c;删除所有的数…

【吊打面试官系列-MySQL面试题】MySQL锁的优化策略?

大家好&#xff0c;我是锋哥。今天分享关于【MySQL锁的优化策略?】面试题&#xff0c;希望对大家有帮助&#xff1b; MySQL锁的优化策略? 1、读写分离 2、分段加锁 3、减少锁持有的时间 4.多个线程尽量以相同的顺序去获取资源不能将锁的粒度过于细化&#xff0c;不然可能会…

算法工程师重生之第十六天(二叉搜索树的最小绝对差 二叉搜索树中的众数 二叉树的最近公共祖先 )

参考文献 代码随想录 一、二叉搜索树的最小绝对差 给你一个二叉搜索树的根节点 root &#xff0c;返回 树中任意两不同节点值之间的最小差值 。 差值是一个正数&#xff0c;其数值等于两值之差的绝对值。 示例 1&#xff1a; 输入&#xff1a;root [4,2,6,1,3] 输出&#x…

语义元分割学习:一种用于少量样本无线图像分类的TinyML方案

论文标题&#xff1a;Semantic Meta-Split Learning: A TinyML Scheme for Few-Shot Wireless Image Classification 中文标题&#xff1a;语义元分割学习&#xff1a;一种用于少量样本无线图像分类的TinyML方案 作者信息&#xff1a; Eslam Eldeeb, Mohammad Shehab, Hirley…

nvm,一款nodejs版本管理工具

背景 在工作中&#xff0c;我们可能同时在进行2个或者多个不同的项目开发&#xff0c;每个项目的需求不同&#xff0c;进而不同项目必须依赖不同版本的NodeJS运行环境&#xff0c;这种情况下&#xff0c;对于维护多个版本的node将会是一件非常麻烦的事情&#xff0c;nvm就是为…

Dapper 如何确保数据的安全性和防止 SQL 注入攻击?

一、什么是SQL注入攻击 SQL注入攻击是一种常见的网络攻击手段&#xff0c;它利用了应用程序中安全措施不足的问题&#xff0c;允许攻击者插入或“注入”一个或多个SQL语句到原本的查询中。这种攻击可以用于获取、篡改或删除数据库中的数据&#xff0c;甚至可以执行一些数据库管…

java:brew安装rabbitmq以及简单示例

什么是消息队列mq 可以看我之前写的这篇 消息队列MQ rabbitmq简介 RabbitMQ是由erlang语言开发&#xff0c;基于AMQP&#xff08;Advanced Message Queue 高级消息队列协议&#xff09;协议实现的消息队列&#xff0c;它是一种应用程序之间的通信方法&#xff0c;消息队列在…

200smart数据日志的功能

称重设备&#xff08;皮带秤&#xff09;读取到的数据值总是一直在跳变&#xff0c;无法正确识别称重传感器读取上来的值来判断产品的重量&#xff0c;虽然在程序中增加了取平均值功能&#xff08;模拟量输入按PLC扫描周期次数求平均值程序&#xff09;&#xff0c;但效果不理想…

什么是聚集索引?

什么是聚集索引&#xff1f; 1、聚集索引的特点2、如何确定聚集索引3、性能优势 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 聚集索引是一种特殊的索引&#xff0c;它直接包含了表中的所有数据行。所以&#xff0c;通过聚集索引&#xf…

代码随想录冲冲冲 Day56 图论Part8

117. 软件构建 这道题是使用拓扑排序的方法 看多个任务有优先级的情况下 怎么排序 对应到这道题就是文件排序 首先要记录每一个点的入度&#xff0c;当一个点的入度为0时&#xff0c;就说明这个点是顶点 然后记录每一个点向那些点相连 之后建立一个queue 寻找一个入度为0的…

弹簧状态检测系统源码分享

弹簧状态检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vis…

Linux中安装ffmpeg

Linux中安装ffmpeg 一、下载二、安装三、测试 一、下载 先到这里下载ffmpeg。 二、安装 先将上传到服务器的某一目录&#xff0c;我这里是&#xff1a; /usr/local/ffmpeg 然后解压&#xff0c;解压命令如下&#xff1a; tar -xvf “你的安装包名称”我的是&#xff1a; ta…

流浪软件uniaccess agent 删除

cmd的C盘找不到就用git rm -rf 之后&#xff0c;只剩下 俩文件夹删不掉 然后360软件就看到了&#xff0c;可惜卸载失败 然后360文件就找到了&#xff0c;彻底删除 再回git 查看 方法 https://blog.51cto.com/u_16099347/11352333 https://blog.csdn.net/xioayu96/article/…

Linux下线程间的通信

为什么需要线程通信&#xff1f; 线程是操作系统调度的最小单元&#xff0c;拥有自己的栈空间。如果线程之间孤立运行&#xff0c;可能会导致资源浪费。线程需要协调工作以完成共同的任务&#xff0c;这就需要线程间相互通信 在 Linux 系统中&#xff0c;线程间通信&#xff…

请问这张图是ai绘画吗?

小白可做&#xff01;全自动AI影视解说一键成片剪辑工具https://docs.qq.com/doc/DYnl6d0FLdHp0V2ll 先来结论&#xff0c;找到用这图的某宝店老板了&#xff0c;老板说不是AI画的。 真相只有一个&#xff0c;有图有真相 再来化身柯南&#xff0c;看看寻找答案的过程 要判断这张…

重考!CSP-J/S 2024第一轮认证泄题后续进展及疑问

2024年9月26日晚间&#xff0c;NOI官网发布了”对部分被认证者进行CSP-J/S 2024第一轮重新认证的公告“&#xff0c;对少儿编程培训机构老师举报陕西鸿泉教育培训机构泄题一事进行了最新的回应。 对涉嫌参加该机构培训的学生的CSP-J/S 2024第一轮入门级、提高级认证成绩不予认可…

<<编码>> 第 21 章 总线连接(Get on the Bus) 示例电路

比较器 info::操作说明 鼠标单击开关切换开合状态 鼠标单击逻辑输入切换 0|1 状态 若上方和左边的输入相同, 则输出高电平 primary::在线交互操作链接 https://cc.xiaogd.net/?startCircuitLinkhttps://book.xiaogd.net/code-hlchs-examples/assets/circuit/code-hlchs-ch21-0…

力扣(LeetCode)每日一题 2207. 字符串中最多数目的子序列

题目链接https://leetcode.cn/problems/maximize-number-of-subsequences-in-a-string/description/?envTypedaily-question&envId2024-09-24 给你一个下标从 0 开始的字符串 text 和另一个下标从 0 开始且长度为 2 的字符串 pattern &#xff0c;两者都只包含小写英文字母…

Vue中使用Hls.js进行视频直播的播放

HLS.js使用文档 1、安装组件&#xff1a; npm install hls.js --save2、引入组件&#xff1a; import Hls from hls.js3、使用组件&#xff1a; // DOM&#xff1a; <video id"video" controls loop"false"></video> // DATA: let hls nul…