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

服装设计公司有哪些优化网站制作公司好吗

服装设计公司有哪些,优化网站制作公司好吗,电子商务专业就业方向专科,平湖有做网站得吗一、JDFrame 介绍 在大数据处理领域#xff0c;Apache Spark以其强大的分布式计算能力和丰富的数据处理API而广受好评。然而#xff0c;在许多日常的软件开发场景中#xff0c;我们面临的数据量可能并不需要Spark这样的分布式系统来处理。相反#xff0c;我们更希望有一种…一、JDFrame 介绍 在大数据处理领域Apache Spark以其强大的分布式计算能力和丰富的数据处理API而广受好评。然而在许多日常的软件开发场景中我们面临的数据量可能并不需要Spark这样的分布式系统来处理。相反我们更希望有一种工具能够在单机环境下提供类似Spark的便捷数据处理能力。Java 8的Stream API虽然提供了一种简化的数据处理方式但在复杂的数据转换和操作上它仍显得有些力不从心。正是在这样的需求背景下JDFrame应运而生。JDFrame借鉴了Spark的API设计理念为Java开发者提供了一套比Java Stream更为强大和灵活的流式数据处理工具。 JDFrame的核心优势之一是其丰富的API。它不仅包含了Java 8 Stream的基础操作还增加了更多高级数据处理功能如窗口函数、复杂条件过滤、自定义聚合以及类似SQL的分组、聚合和连接操作。这些额外的功能使得JDFrame能够轻松应对复杂的数据操作需求为开发者提供了更大的灵活性和便利性。 总之就是你可以使用SQL处理的思路去处理数据。 Githb 地址https://github.com/burukeYou/JDFrame 使用示例 添加依赖 dependencygroupIdio.github.burukeyou/groupIdartifactIdjdframe/artifactIdversion0.0.4/version /dependencypublic class JdframeTest {DataAllArgsConstructorNoArgsConstructorpublic static class UserVO {private int id;private String name;private Integer age;private Integer score;}private static final ListUserVO userVOS Arrays.asList(new UserVO(1, 张三, 20, 90),new UserVO(2, 李四, 21, 92),new UserVO(3, 王五, 30, 95),new UserVO(4, 赵六, 15, 85),new UserVO(5, 小明, 32, 88),new UserVO(6, 小红, 18, 94),new UserVO(7, 小兰, 19, 75),new UserVO(8, 小青, 12, 60),new UserVO(9, 小王, 16, 34),new UserVO(10, 小李, 17, 49),new UserVO(11, 张三, 19, 59));public static void main(String[] args) {System.out.println(查看分数在 60 - 90 之间的姓名、分数的 Top5);SDFrameFI2String, BigDecimal sdf1 SDFrame.read(userVOS).whereNotNull(UserVO::getScore) // 不为空.whereBetween(UserVO::getScore, 60, 90) // 范围过滤.groupBySum(UserVO::getName, UserVO::getScore) // 聚合求和.sortDesc(FI2::getC2) // 根据值降序排列.cutFirst(5); // 保留 Top5sdf1.show(); // 查看数据System.out.println(查看姓名中 张 开头的信息);SDFrameUserVO sdf2 SDFrame.read(userVOS).whereNotNull(UserVO::getName) // 不为空.whereLikeLeft(UserVO::getName, 张); // 模糊查询sdf2.show();System.out.println(查看80分以上的平均年龄);BigDecimal sdf3 SDFrame.read(userVOS).whereNotNull(UserVO::getAge) // 不为空.whereNotNull(UserVO::getName) // 不为空.whereGt(UserVO::getScore,80) // 分数大于80.avg(UserVO::getAge); // 计算平均System.out.println(sdf3);}}运行结果 二、JDFrame VS Java Stream JDFrame 在功能上要比 Java Stream 强大在性能上相比呢下面构建一千万条数据进行分组计算后取 Top 数据看谁处理的更快 public class JdframePropertyTest {DataAllArgsConstructorNoArgsConstructorpublic static class UserVO {private int id;private String name;private Integer age;private Integer score;}public static void main(String[] args) {ListUserVO userVOS new ArrayList();Random random new Random();// 构造一千万条数据for (int i 0; i 10000000; i) {userVOS.add(new UserVO(1, String.valueOf(i), (random.nextInt(91) 10), (random.nextInt(71) 30)));}System.out.println(准备测试数据完成当前数据量userVOS.size());// 根据每个年龄进行分组求和最后取出分数最大的 top5 的年龄和总分数// java stream 处理System.out.println(开始 java stream 处理。。。);long t1 System.currentTimeMillis();ListMap.EntryInteger, Integer streamTop userVOS.stream().filter(Objects::nonNull).filter(u - Objects.nonNull(u.getAge())).filter(u - Objects.nonNull(u.getScore())).collect(Collectors.groupingBy(UserVO::getAge, Collectors.summingInt(UserVO::getScore))).entrySet().stream().sorted(Map.Entry.Integer, IntegercomparingByValue().reversed()).limit(5).collect(Collectors.toList());System.out.println(java stream 耗时 (System.currentTimeMillis() - t1) , 结果如下);streamTop.forEach(map - System.out.println(age: map.getKey() , score: map.getValue()));streamTop.clear();System.out.println(开始 jdFrame 处理。。。);t1 System.currentTimeMillis();ListFI2Integer, BigDecimal jdFrameTop SDFrame.read(userVOS).whereNotNull(UserVO::getAge).whereNotNull(UserVO::getScore).groupBySum(UserVO::getAge, UserVO::getScore).sortDesc(FI2::getC2).cutFirst(5).toLists();System.out.println(jdFrame 耗时 (System.currentTimeMillis() - t1) , 结果如下);jdFrameTop.forEach(fi2 - System.out.println(age: fi2.getC1() , score: fi2.getC2()));}}从结果上看JDFrame 的速度逊色一些但如果你处理数据量不大的情况JDFrame 确实是一个非常好的工具。 比如数据量在一百万的时候差距明显减少 下面可以学习下 JDFrame 的 Api 。 三、JDFrame Api 3.1 Where 条件过滤 3.1.1 精确过滤 SDFrame.read(userVOS)// is not nll.whereNotNull(UserVO::getName)// .whereEq(UserVO::getName, 张三)// ! , .whereNotEq(UserVO::getName, 李四);3.1.2 模糊过滤 SDFrame.read(userVOS)// like %小%.whereLike(UserVO::getName, 小)// like 小%.whereLikeLeft(UserVO::getName, 小)// like %小.whereLikeRight(UserVO::getName, 小);3.1.3 范围过滤 SDFrame.read(userVOS)// .whereGt(UserVO::getScore, 60)// .whereGe(UserVO::getScore, 60)// .whereLe(UserVO::getScore, 60)// .whereLt(UserVO::getScore, 60)// and .whereBetween(UserVO::getScore, 60, 80)// and .whereBetweenR(UserVO::getScore, 60, 80)// and .whereBetweenL(UserVO::getScore, 60, 80)// in.whereIn(UserVO::getScore, Arrays.asList(60, 70, 80))// not in.whereNotIn(UserVO::getScore, Arrays.asList(60, 70, 80));3.2 数据统计 3.2.1 分组求和 JDFrameUserVO frame JDFrame.read(userVOS); // select name,sum(score) from userVOs group by name frame.groupBySum(UserVO::getName, UserVO::getScore);// select name,age,sum(score) from userVOs group by name, age frame.groupBySum(UserVO::getName, UserVO::getAge, UserVO::getScore);3.2.2 分组求最大最小值 JDFrameUserVO frame JDFrame.read(userVOS);// select name,max(age) from userVOs group by name frame.groupByMaxValue(UserVO::getName, UserVO::getScore);// 和 groupByMaxValue 一致拿到的是对象 frame.groupByMax(UserVO::getName, UserVO::getScore);// select name,min(score) from userVOs group by name frame.groupByMinValue(UserVO::getName, UserVO::getScore);// 和 groupByMinValue 一致拿到的是对象 frame.groupByMaxMin(UserVO::getName, UserVO::getScore);3.2.3 分组计数 JDFrameUserVO frame JDFrame.read(userVOS);// select count(1) from userVOs group by name frame.groupByCount(UserVO::getName);// select count(1) from userVOs group by name, age frame.groupByCount(UserVO::getName, UserVO::getAge);// select count(1) from userVOs group by name, age, score frame.groupByCount(UserVO::getName, UserVO::getAge, UserVO::getScore);// select name,sum(score),count(1) from userVOs group by name frame.groupBySumCount(UserVO::getName, UserVO::getScore);3.2.4 整体统计 JDFrameUserVO frame JDFrame.read(userVOS); // select max(score) from userVOs frame.maxValue(UserVO::getScore); // 和 maxValue 一致拿到的是对象 frame.max(UserVO::getScore); // select min(score) from userVOs frame.minValue(UserVO::getScore); // 和 minValue 一致拿到的是对象 frame.min(UserVO::getScore); // select avg(score) from userVOs frame.avg(UserVO::getScore); // select sum(score) from userVOs frame.sum(UserVO::getScore); // select max(score),min(score) from userVOs frame.maxMinValue(UserVO::getScore); // 和 maxMinValue 一致可以拿到对象 frame.maxMin(UserVO::getScore);3.3 排序 JDFrameUserVO frame JDFrame.read(userVOS); // select * from userVOS order by score desc frame.sortDesc(UserVO::getScore); // select * from userVOS order by age asc frame.sortAsc(UserVO::getAge); // select * from userVOS order by score asc, age asc frame.sortDesc(Sorter.sortDescBy(UserVO::getScore).sortAsc(UserVO::getAge)); // 自定义排序规则 frame.sortAsc(Comparator.comparing(e - {if (e.getAge() 20 e.getScore() 80) {return 1;} else {return 0;} }));3.4 去重 JDFrameUserVO frame JDFrame.read(userVOS); // 根据对象去重 frame.distinct(); // 根据某个字段去重 frame.distinct(UserVO::getName); // 根据多个字段先后去重 frame.distinct(UserVO::getName).distinct(UserVO::getAge);3.5 join 连接 JDFrameUserVO frame1 JDFrame.read(userVOS); JDFrameUserVO frame2 JDFrame.read(userVOS); // 内连接 JDFrameUserVO join frame1.join(frame2, (f1, f2) - Objects.equals(f1.getId(), f2.getId()), (f1, f2) - {// 具体合并曹组f1.setName(f2.getName());return f1; }); // 左连接 JDFrameUserVO leftJoin frame1.leftJoin(frame2, (f1, f2) - Objects.equals(f1.getId(), f2.getId()), (f1, f2) - {// 具体合并曹组f1.setName(f2.getName());return f1; }); // 右连接 JDFrameUserVO rightJoin frame1.rightJoin(frame2, (f1, f2) - Objects.equals(f1.getId(), f2.getId()), (f1, f2) - {// 具体合并曹组f1.setName(f2.getName());return f1; });3.6 其他操作 JDFrameUserVO frame JDFrame.read(userVOS); // 打印数据 frame.show(); // 获取表头 frame.columns(); // 获取某一列数据 frame.col(UserVO::getName); // 获取第一条数据 frame.head(); // 获取前 5 数据 frame.head(5); // 获取最后一个数据 frame.tail(); // 获取最后5条数据 frame.tail(5); // 分页获取数据 frame.page(1, 5);// JDFrame 新增数据 frame.append(new UserVO(12, 小九, 19, 59)); // 多个 JDFrame 合并数据 frame.union(JDFrame.read(userVOS));// 数据截取 // 截取前5个数据 frame.cutFirst(5); // 截取最后5个数据 frame.cutLast(5); // 指定范围截取 frame.cut(2, 5); // 分页截取 frame.cutPage(1, 5);// 数据拆分, 分为 5 个一组 frame.partition(5);
http://www.hkea.cn/news/14329957/

相关文章:

  • 国内精品网站建设wordpress wap模板下载
  • 建材网站制作网站建设信息科技公司
  • 做装修网站如何站长工具怎么关闭
  • 奉贤免费网站建设济南网站建设山东聚搜网力推
  • 网站建设流程机构wordpress微博头条
  • 岳麓 网站设计物流门户网站开发 报价
  • 帮别人做网站网站建设使用哪种语言好
  • 解析网站dns网站建设与管理课程视频
  • 南昌网站建设公司市场网站建设制度制定情况
  • 长沙便宜网站建设软件研发和开发哪个工资高
  • 外贸网站怎么建设建设局网站作用
  • 昆山外贸网站建设推广河南省住房建设厅网站首页
  • 深圳网站建设销售前景河北省建设工程管理信息网官网
  • 电子商务网站运营济南手机网站建设公司
  • 手机网站搭建教程wordpress如何导航网站
  • 金华永康义乌网站建设巴南集团网站建设
  • 企业设计网站建筑公司企业如何成功
  • 想做企业网站虚拟主机比较
  • 播视频网站开发Wordpress的根目录在哪
  • 电商网站代码模板网页制作模板中学
  • 国内定机票网站建设有需要网站建设网站推广请找我
  • 书店商城网站html模板下载互联网 网站建设价格
  • 陕西宏远建设集团网站企业网站开发摘要
  • 宝安建设网站软件app网址怎么找
  • jsp网站开发大作业社联网站建设的目的
  • 做公司做网站有用吗杭州商业空间设计公司
  • 河北省城乡住房和城乡建设厅网站郴州网络营销
  • 如何微信做演讲视频网站网络推广计划制定步骤
  • 用vue做网站一般用什么组件库东阳便宜自适应网站建设优惠
  • 有做任务赚赏金的网站吗凯里网站设计公司哪家好