Java版LINQ工具包devtools-beans-streaming使用介绍

2024-04-15 18:18

本文主要是介绍Java版LINQ工具包devtools-beans-streaming使用介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

devtools-beans-streaming包是devtools系列的工具包之一,它是一个对对象列表(或称为结果集)进行查询或聚合等操作的解决方案, 提供了类似于C#中的LINQ功能

Maven:
		<dependency><groupId>com.github.paganini2008</groupId><artifactId>devtools-beans-streaming</artifactId><version>2.0.2</version></dependency>
Jdk版本:

jdk 1.8+

API使用说明:

devtools-beans-streaming操作的对象通常是一个List

举例说明:

比如有这样一个对象:

@Getter
@Setter
@ToString
public class Product {private int id;private String name;private String location;private Date created;private Date expired;private Float price;private BigInteger sales;private boolean export;private Long number;private BigDecimal freight;private Style style;private Salesman salesman;public static enum Style {HARD, SOFT;}@Getter@Setter@ToStringpublic static class Salesman {private String name;private String password;public Salesman(String name, String password) {this.name = name;this.password = password;}}}

然后定义一个List, 生成一批对象,随机赋值
比如:

    // 定义一个Listprivate static final List<Product> products = new ArrayList<Product>(); static {String[] users = new String[] { "Petter", "Jack", "Tony" };String[] locations = new String[] { "London", "NewYork", "Tokyo", "HongKong", "Paris" };for (int i = 0; i < 10000; i++) {Product product = new Product();product.setCreated(DateUtils.valueOf(2020, RandomUtils.randomInt(1, 12), RandomUtils.randomInt(1, 28)));product.setExpired(DateUtils.addDays(product.getCreated(), 90));product.setExport(RandomUtils.randomBoolean());product.setFreight(BigDecimal.valueOf(RandomUtils.randomFloat(10, 100)).setScale(2, RoundingMode.HALF_UP));product.setId(i + 1);product.setLocation(RandomUtils.randomChoice(locations));product.setName("Product-" + product.getId());product.setNumber(RandomUtils.randomLong(1, 1000));product.setPrice(RandomUtils.randomFloat(10, 1000, 2));product.setSales(BigInteger.valueOf(RandomUtils.randomLong(10000, 100000)));product.setStyle(Style.values()[RandomUtils.randomInt(0, 2)]);product.setSalesman(new Product.Salesman(RandomUtils.randomChoice(users), "123456"));products.add(product);}}
示例1
		Predicate<Product> predicate = Restrictions.eq("location", "London");Selector.from(products).filter(predicate).list().forEach(product -> {System.out.println(product);});
// Equivalent to: select * from Product where location='London'
示例2
		Predicate<Product> predicate = Restrictions.lte("created", new Date());predicate = predicate.and(Restrictions.eq("salesman.name", "Petter"));Selector.from(products).filter(predicate).list().forEach(product -> {System.out.println(product);});
// select * from Product where created<= now() and salesman.name='Petter'
示例3
        Selector.from(products).groupBy("location", String.class).setTransformer(new View<Product>() {protected void setAttributes(Tuple tuple, Group<Product> group) {tuple.set("maxPrice", group.max("price", Float.class));tuple.set("minPrice", group.min("price", Float.class));tuple.set("avgFreight", group.avg("freight"));tuple.set("sumSales", group.sum("sales"));}}).list().forEach(tuple -> {System.out.println(tuple);});
// Equivalent to: select location,max(price) as maxPrice, min(price) as minPrice,avg(freight) as avgFreight,sum(sales) as sumSales from Product group by location
示例4
		Selector.from(products).groupBy("location", String.class).groupBy("style", Product.Style.class).having(group -> {return group.avg("freight").compareTo(BigDecimal.valueOf(55)) > 0;}).setTransformer(new View<Product>() {protected void setAttributes(Tuple tuple, Group<Product> group) {tuple.set("maxPrice", group.max("price", Float.class));tuple.set("minPrice", group.min("price", Float.class));tuple.set("avgFreight", group.avg("freight"));tuple.set("sumSales", group.sum("sales"));}}).list().forEach(tuple -> {System.out.println(tuple);});
// Equivalent to: select location,style,max(price) as maxPrice, min(price) as minPrice,avg(freight) as avgFreight,sum(sales) as sumSales from Product group by location,style having avg(freight) > 55
示例5:
		Sorter<Product> sorter = Orders.descending("price", BigDecimal.class);Selector.from(products).orderBy(sorter).list(100).forEach(product -> {System.out.println("Name: " + product.getName() + ", Price: " + product.getPrice() + ", Freight: " + product.getFreight());});
// Equivalent to: select name,price from Product order by price desc limit 100

源码地址:https://github.com/paganini2008/devtools.git

这篇关于Java版LINQ工具包devtools-beans-streaming使用介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/906560

相关文章

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.