当前位置: 首页 > news >正文

大集合拆分成多个小集合

文章目录

  • 1. 场景
  • 2. 拆分集合方法(写了三种)
  • 3. 格式化打印方法

1. 场景

在数据库批量操作时,有可能数据量过大,不能一次性操作,所以需要将大集合拆分为多个小集合进行多次操作

2. 拆分集合方法(写了三种)

import com.google.common.collect.Lists;
import com.xin.demo.fastjsondemo.FastJsonFormatPrintUtils;
import org.apache.commons.collections4.CollectionUtils;import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.IntStream;public class PartitionListDemo {private static final int PARTITION_SIZE = 10;public static void main(String[] args) {// 大集合List<String> list = new ArrayList<>();for (int i = 0; i < 33; i++) {list.add("xinliushijian" + i);}// 方法1 guava工具List<List<String>> partitionList = Lists.partition(list, PARTITION_SIZE);FastJsonFormatPrintUtils.formatPrint(partitionList);System.out.println("===============");// 方法2 stream流实现List<List<String>> partitionList1 = partList1(list, PARTITION_SIZE);FastJsonFormatPrintUtils.formatPrint(partitionList1);// 方法3 普通方法实现partList2(list, PARTITION_SIZE);}public static <T> List<List<T>> partList1(List<T> list, int size) {if (CollectionUtils.isEmpty(list) || size < 1) {return new ArrayList<>();}List<List<T>> partList = IntStream.range(0, list.size()).boxed().collect(Collectors.groupingBy(index -> index / size)).values().stream().map(indices -> indices.stream().map(list::get).collect(Collectors.toList())).collect(Collectors.toList());return partList;}public static <T> List<List<T>> partList2(List<T> list, int size) {if (CollectionUtils.isEmpty(list) || size < 1) {return new ArrayList<>();}List<List<T>> allPartList = new ArrayList<>();for (int i = 0; i < list.size(); i+=size) {if (i + size > list.size()) {size  = list.size() - i;}List<T> parList = list.subList(i, i + size);allPartList.add(parList);}FastJsonFormatPrintUtils.formatPrint(allPartList);return allPartList;}}

3. 格式化打印方法

import com.alibaba.fastjson.serializer.SerializerFeature;
import com.alibaba.fastjson.JSON;public class FastJsonFormatPrintUtils {public static void formatPrint(Object object) {String pretty = JSON.toJSONString(object, SerializerFeature.PrettyFormat, SerializerFeature.WriteMapNullValue,SerializerFeature.WriteDateUseDateFormat);System.out.println(pretty);}}
http://www.lryc.cn/news/143906.html

相关文章:

  • linux————LVS集群
  • 软考高级系统架构设计师系列论文七十一:论行业应用软件系统的开发规划
  • vue2 自定义指令,插槽
  • oracle超详细语法和备份工具
  • Redis的持久化机制是什么?各自的优缺点?
  • 机器学习:什么是分类/回归/聚类/降维/决策
  • 算法通关村第5关【白银】| 哈希和栈经典算法题
  • CrystalNet .Net VCL for Delphi Crack
  • 云计算在线实训系统建设方案
  • C++ 珠心算测验
  • prometheus+cadvisor监控docker容器
  • 13、Vue3 大事件管理系统
  • Redis三种特殊数据类型
  • python 模块BeautifulSoup 从HTML或XML文件中提取数据
  • VS Code插件汇总
  • QWidget
  • 【大数据】Linkis:打通上层应用与底层计算引擎的数据中间件
  • 权限提升-数据库提权-MSF-UDF提权
  • 基于XL32F003单片机的可控硅调光方案
  • 【ag-grid-vue】列定义(Updating Column Definitions)
  • mysql sql_mode数据验证检查
  • Prompt召唤 AI “生成”生产力,未来已来
  • 【0day】复现时空智友企业流程化管控系统SQL注入漏洞
  • python编程中fft的优缺点,以及如何使用cuda编程,cuda并行运算,信号处理(推荐)
  • 统计学补充概念-16-支持向量机 (SVM)
  • Python“牵手”天猫商品列表数据,关键词搜索天猫API接口数据,天猫API接口申请指南
  • SQL 错误 [22007]: ERROR: invalid input syntax for type date: ““
  • SpringBootWeb案例 Part 2
  • 4.14 HTTPS 中 TLS 和 TCP 能同时握手吗?
  • 游戏开发服务器选型的横向对比