分项加载页面统计数据

我们在做一个统计页面时,原来大约有1000万左右的数据进行查询,还可以接受,但是随着业务量的增大,目前有3000多万的数据来统计,一次统计出查询结果就很慢很慢,有时候会出现超时异常。
为了解决这个问题,我们使用分项加载的统计策略。主要的策略是把统计页面的每一个统计项找一个key,然后分项查询得出结果。这样能够提高用户的体验。

主要是两方面的改进。
一是前端页面进行修改

loadData() {//分两步,先取出检查项,填写到表里面。console.log("第一步,取出检查项");getCheckItemsStatistics({year: this.selectedYear,month: this.selectedMonth,areaNumbers: this.selectedAreaNumber,foodTypes: this.selectedFoodTypes,itemDepth: this.selectedItemDepth}).then(async response => {if (response.state == 200) {const itemNumbers = [];for (const item of response.data) {// 在这里对每个 item 进行处理// 例如获取某个键的值const itemNumber = item['_ITEMNUMBER'];itemNumbers.push(itemNumber);}//补充其它的值为0this.tableData = this.processKey(response.data);this.isLoading = false;//console.log("第二步,取出检查项的统计数据");let rowNumber = 0;for (const itemNumber of itemNumbers) {//console.log("细分第二步,查询" + itemNumber + "的统计数据");// 假设这是你的计算逻辑this.tableData.at(rowNumber)['loading'] = true;// for (const row of this.tableData) {//   row.loading = true; // 开始计算前设置加载状态为trueawait getCheckEveryItemStatistics({year: this.selectedYear,month: this.selectedMonth,areaNumbers: this.selectedAreaNumber,itemNumber: itemNumber,foodTypes: this.selectedFoodTypes,itemDepth: this.selectedItemDepth,isAreasCondition: this.isAreasCondition}).then(async response1 => {if (response1.state == 200) {//console.log("细分第三步,取出" + itemNumber + "的统计数据"+JSON.stringify(response1.data));for (const obj of this.tableData) {if (obj['_ITEMNUMBER'] == itemNumber) {obj['SUM_COUNT'] = response1.data[0]['SUM_COUNT'];obj['TRUE_COUNT'] = response1.data[0]['TRUE_COUNT'];obj['FALSE_COUNT'] = response1.data[0]['FALSE_COUNT'];obj['MISSING_COUNT'] = response1.data[0]['MISSING_COUNT'];obj['TRUE_PCT'] = response1.data[0]['TRUE_PCT'];obj['FALSE_PCT'] = response1.data[0]['FALSE_PCT'];obj['MISSING_PCT'] = response1.data[0]['MISSING_PCT'];}}}}).catch(() => {}).finally(() => {//this.isLoading=false;})this.tableData.at(rowNumber)['loading'] = false; // 计算完成后设置加载状态为falserowNumber++;}// }}}).catch(err => {}).finally(() => {this.isLoading = false;})//这是原来的代码,上面是改进的代码//   getCheckItemsCheckSummaryStatistics({//       year: this.selectedYear,//       month: this.selectedMonth,//       areaNumbers: this.selectedAreaNumber,//       itemNumber:'1.1',//       foodTypes: this.selectedFoodTypes,//       itemDepth: this.selectedItemDepth,//       isAreasCondition: this.isAreasCondition//   }).then(response => {//       if(response.state == 200) {//           this.tableData = this.processKey(response.data);//       }//   }).catch(() => {//   }).finally(() => {//       this.isLoading = false;//   });},

二是后台页面添加统计项参数

	@RequestMapping(value = "/getCheckEveryItemStatistics", method = {RequestMethod.POST})APIResult<List<Map<String, Object>>> getCheckEveryItemStatistics(@RequestParam(required = false) String year,@RequestParam(required = false) String month,@RequestParam(required = false) String areaNumbers,@RequestParam(required = true) String itemNumber,@RequestParam(required = false) String foodTypes,@RequestParam(required = false) Integer itemDepth,@RequestParam(required = false) boolean isAreasCondition);

三是对统计图添加自动计算规则

      <div class="chart-box"><vue-chart:id="id":option="chartOption"width="calc(100% - 40px)"height="350px"/></div>
computed: {chartOption() {const option = this.dataOption;let trueCount = 0;let falseCount = 0;let missingCount = 0;this.tableData.forEach(item => {trueCount += item['TRUE_COUNT'];falseCount += item['FALSE_COUNT'];missingCount += item['MISSING_COUNT'];});option.series[0].data = [{value: trueCount, name: '评价(是)'},{value: falseCount, name: '评价(否)'},{value: missingCount, name: '评价(合理缺项)'}];return JSON.parse(JSON.stringify(option));}},

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

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

相关文章

云计算数据中心(一)

目录 一、云数据中心的特征二、云数据中心网络部署&#xff08;一&#xff09;改进型树结构&#xff08;二&#xff09;递归层次结构&#xff08;三&#xff09;光交换网络&#xff08;四&#xff09;无线数据中心网络&#xff08;五&#xff09;软件定义网络 一、云数据中心的…

Briefcase:将Python项目转化为多平台应用的利器

文章目录 引言官网链接原理基础使用安装 Briefcase初始化项目构建应用创建应用包 高级使用应用程序配置和定制化与打包工具的集成自动处理依赖关系 优缺点优点缺点 总结 引言 Briefcase 是一个功能强大的工具&#xff0c;主要用于将 Python 项目转化为多种平台的独立本地应用。…

java 项目使用 acitiviti 流程引擎中的人员设置

学习目标&#xff1a; 目标 [ ]了解 java 项目使用 acitiviti 流程引擎中的人员设置 知识小记&#xff1a; - [x] 1、人员选择说明 - [x] 2、分配任务候选人 任务的候选人是指有权限对该任务进行操作的潜在用户群体&#xff0c;这个用户群体有权限处理(处理、完成)该任务…

最多可以派出多少支球队

最多可以派出多少支球队 解决“最多可以派出多少支球队”的问题需要准确理解题目要求&#xff0c;选择合适的算法&#xff08;如贪心算法和双指针技术&#xff09;&#xff0c;并注意对原始数据进行适当的预处理&#xff08;如排序&#xff09;。在编程实现过程中&#xff0c;有…

MySQL索引重要知识点

1.什么是索引&#xff1f; 索引在项目中是比较常见的&#xff0c;它是帮助MySQL高效获取数据的数据结构&#xff0c;主要是用来提高数据检索的效率&#xff0c;降低数据库的I0成本&#xff0c;同时通过索引列对数据进行排序&#xff0c;降低数据排序的成本&#xff0c;也能降低…

Vue2中的进度条案例

v-bind对于样式控制的增强--操作style 语法&#xff1a; :style “样式对象” 适用于某个具体属性的动态设置 <div class"box" :style"{css属性名1:css属性值,css属性名2:css属性值}"></div> <!DOCTYPE html> <html lang"en&…

java.sql.SQLException: Unknown system variable ‘query_cache_size‘【Pyspark】

1、问题描述 学习SparkSql中&#xff0c;将spark中dataframe数据结构保存为jdbc的格式并提交到本地的mysql中&#xff0c;相关代码见文章末尾。 运行代码时报出相关配置文件错误&#xff0c;如下。 根据该报错&#xff0c;发现网络上多数解决方都是基于java开发的解决方案&a…

uniapp字符串转base64,无需导入依赖(多端支持)

使用示例 import { Base64Encode, Base64Decode } from "@/utils/base64.js" base64.js const _keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";export const Base64Encode = (text)

网络准入控制设备是什么?有哪些?网络准入设备臻品优选

小李&#xff1a;“小张&#xff0c;最近公司网络频繁遭遇外部攻击&#xff0c;我们得加强一下网络安全了。” 小张&#xff1a;“是啊&#xff0c;我听说实施网络准入控制是个不错的选择。但具体什么是网络准入控制设备&#xff1f;我们有哪些选择呢&#xff1f;” 小李微笑…

linux文件处理----学习记录

cat file1 file2 >> combined_filefile1 file2会依次加到指定的文件后面 查看文件里有多少行&#xff1a;wc -l filename 搜索某个文件里面是否包含字符串&#xff1a; grep "search-content" filename 打印偶数行内容&#xff1a; awk NR%20 test.txt 循…

iredmail服务器安装步骤详解!如何做配置?

iredmail服务器安全性设置指南&#xff1f;怎么升级邮件服务器&#xff1f; iredmail是一个功能强大的邮件服务器解决方案&#xff0c;它集成了多个开源软件&#xff0c;使您能够快速部署和管理邮件服务。AokSend将逐步引导您完成安装过程&#xff0c;无需深入的编程知识即可轻…

AI智能名片在Web 3.0技术栈中的应用与前景研究

摘要&#xff1a;在Web 3.0的浪潮中&#xff0c;AI智能名片作为一种创新的数字工具&#xff0c;正逐步渗透到商业交流的各个层面。本文深入探讨了AI智能名片在Web 3.0技术栈中的具体应用&#xff0c;详细分析了其背后的技术支撑、应用场景、优势以及面临的挑战。通过案例分析、…

A Survey on Multimodal Large Language Models综述

论文题目:A Survey on Multimodal Large Language Models 论文地址:https://arxiv.org/pdf/2306.13549 话题:多模态LLMs综述 MLLMs Paper: https://github.com/BradyFU/Awesome-Multimodal-Large-Language-Models 1. 摘要 近期,以GPT-4V为代表的跨模态大型语言模型(MLLM…

Java版【植物大战僵尸+源码】

上期回顾&#xff1a; 今天给大家推荐一个Gtihub开源项目&#xff1a;PythonPlantsVsZombies&#xff0c;翻译成中就是植物大战僵尸。 《植物大战僵尸》是一款极富策略性的小游戏。可怕的僵尸即将入侵&#xff0c;每种僵尸都有不同的特点&#xff0c;例如铁桶僵尸拥有极强的抗…

用 LLM 构建企业专属的用户助手

TL;DR 本文主要介绍了 PingCAP 如何使用大型语言模型&#xff08;Large Language Model&#xff0c;LLM&#xff09;构建一个搭载企业专属知识库的智能客服机器人。除了采用行业内通行的基于知识库的问题解答方法&#xff0c;我们还尝试让模型在“小样本&#xff08;Few-Shot&…

Leetcode 100361100367.切割蛋糕的最小总开销

Medium&#xff1a;动态规划搜索&#xff08;实际就是优化后的dfs&#xff09; class Solution { public: int f[25][25][25][25] {0};int dp(int row1, int col1, int row2, int col2, vector<int>& horizontalCut, vector<int>& verticalCut){if(row1 …

力扣726.原子的数量

力扣726.原子的数量 倒序遍历字符串 d保存括号外倍数s存原子类型ha存括号外倍数cnt存当前原子倍数遇到数字就存在d中遇到) 就将d记录下来入栈遇到( 就栈顶(当前结束的括号的倍数)出栈 cnt / st.top();遇到字母就记录 当发现大写时 翻转字符串得到原子类型 class Solution {p…

Autosar RTE配置-Assembly和Delegation的使用-基于ETAS软件

文章目录 前言Assembly和Delegation的含义Delegation的使用Assembly的使用总结 前言 RTE中的Compostion内部的SWC之间的连接使用Assembly Connector进行连接。这样的连接一般都是一个SWC的Pport对应另一个SWC的Rport。而Autosar软件中往往不只一个Composition(一般可以以核的数…

Ubuntu的磁盘扩容遇到的问题

1.先用终端上的命令查看磁盘的使用情况 #查看磁盘空间容量的占用情况 $ df -h #查看当前文件夹中&#xff0c;各个文件占用磁盘空间的情况 $ du -sh* 如果容量少的话&#xff0c;需要尽快扩容 2.开机前的扩容 2.1 VMware 扩展磁盘空间 关闭当前客户机&#xff0c;在编辑虚拟…

第三季度加密市场动荡:市场缺乏炒作题材,波动加剧

摘要 根据 Arkham 的数据&#xff0c;德国政府联邦刑事调查局 (BKA) 可能已完成抛售&#xff0c;其持有量从 6 月中旬的约 50,000 BTC&#xff08;35.5 亿美元&#xff09;减少到 7 月 12 日的数据为 0 BTC。市场担忧美国经济在今年晚些时候或 2025 年初陷入衰退&#xff0c;导…