Java 8中发布的Java Stream API已被证明是一种表达应用程序逻辑的高效、简洁而直观的方法。新启动的开源项目JPAstreamer允许您使用Java Streams表示Hibernate或其他JPA数据库查询。在本文中,我们将向您展示如何扩展现有数据库应用程序的API以即时处理Stream查询。

为了让您快速了解JPAstreamer的功能,我们首先向您展示一个在包含任意用户(属性包括名字和姓氏)的数据库表上运行Stream的示例:

java 流式 大数据 导出 excel_Java

这将打印十个用户,这些用户的名字以字母A开头,字母A根据用户的姓氏反向排列。这说明了如何将所需结果集轻松描述为Stream运算符的管道。

从表面上看,似乎提供的Stream需要在JVM中实现User表中的每一行,实际上对Stream进行了优化并呈现给JPA查询。因此,Stream查询的性能与JPQL或Criteria Builder等替代方法一样,但是JPAstreamer构成了一种简化的,类型安全的表达查询的方法。

java 流式 大数据 导出 excel_JPA_02

JPAstreamer如何工作

JPAstreamer在您的Maven / Gradle构建中添加了单个依赖项,从而将其插入您的应用程序。

像著名的Java库Lombok一样,JPAstreamer使用注释处理器在编译时形成元模型。它检查标记有标准JPA批注@Entity的所有类,并为每个实体Foo.class生成一个对应的Foo $ .class。生成的类将实体属性表示为字段,这些字段用于形成User $ .firstName.startsWith(“ A”)形式的谓词,JPAstreamer的查询优化器可以解释这些谓词。

java 流式 大数据 导出 excel_元模型_03

重要的是,JPAstreamer不会更改或干扰现有的代码库,而只是扩展API来处理Java Stream查询。此外,元模型放置在“目标”文件夹中的“生成的源”中,无需使用源代码进行检入或测试。

java 流式 大数据 导出 excel_JPA_04

流处理

现在,我们将引导您完成在数据库应用程序中设置JPAstreamer的简单过程。为此,您的应用程序必须使用Java 8(或更高版本)和Hibernate或负责对象持久性的其他JPA提供程序(如果您希望在不使用JPA的情况下使用Stream API,最好使用开源的Stream ORM Speedment)。

java 流式 大数据 导出 excel_java hql 查询所有内容_05

如前所述,仅需要向您的Maven / Gradle构建中添加一个依赖项,并重新构建应用程序以生成JPAstreamer元模型。

完成简单的设置后,您需要像这样获得JPAStreamer的实例:

java 流式 大数据 导出 excel_java hql 查询所有内容_06

您应该将字符串“ db-name”替换为您要查询的持久性单元的名称。在您的JPA配置文件(通常称为persistence.xml)中的标签下进行查找。

JPAstreamer实例提供对方法.stream()的访问,该方法接受您要流式传输的实体的名称。要查询用户表,只需键入:

java 流式 大数据 导出 excel_java hql 查询所有内容_07

这将返回类型为Stream 的所有用户行的流。有了Stream源,您可以随意添加任何Java Stream操作来形成数据流经的管道(数据流是概念性的图像,而不是代码执行方式的实际描述)。例如:

java 流式 大数据 导出 excel_JPA_08

该流收集列表中20岁以下用户的姓名。User $是指生成的实体,它是JPAstreamer的元模型的一部分。该实体用于为操作(例如.filter()和.sort())形成谓词和比较器,这些操作可以利用现代IDE中的代码完成功能迅速组成。

这是另一个例子,该示例使用组合谓词计算来自德国并被命名为“奥托”的所有用户:

java 流式 大数据 导出 excel_JPA_09

结论

在本文中,我们展示了如何将开源库JPAstreamer与Hibernate(或任何JPA提供程序)集成在一起,以构成类型安全和可表达的数据库查询作为标准Java Streams。