java 实现流式返回数据 sse_数据库

hibernate

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

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

jpaStreamer.stream(User. class )

    .filter(User$.firstName.startsWith(”A”)    .sort(User$.lastName.reversed())    .limit( 10 )    .forEach(System.out::println);

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

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

JPAstreamer如何工作

JPAstreamer在您的Maven / Gradle构建中添加了单个依赖项,从而将其插入您的应用程序。 具体的依赖关系在这里描述。

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

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

让我们流媒体

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

如前所述,安装仅需要在Maven / Gradle构建中添加一个依赖项( 在此进行描述),并重新构建应用程序以生成JPAstreamer元模型。

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

JPAStreamer jpaStreamer = JPAStreamer.of( "db-name" );

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

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

jpaStreamer.stream(User. class );

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

List<String> users = jpaStreamer.stream(User. class )

    .filter(User$.age.greaterThan( 20 ))    .map(u -> u.getFirstName() + ” ” + u.getLastName()) .filter(User$.age.greaterThan( ))    .map(u -> u.getFirstName() + ” ” + u.getLastName())

    .collect(Collectors.toList);

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

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

long count = jpaStreamer.stream(User. class )

    .filter(User$.country.equal(”Germany”).and(User$.firstName.equal(”Otto”))    .count();

结论

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

资源资源

  • GitHub: github.com/speedment/jpa-streamer
  • 主页: jpastreamer.org
  • 文档: github.io/jpa-streamer
  • Gitter支持聊天: gitter.im/jpa-streamer
s

Per MinborgJulia·古斯塔夫森(Julia Gustafsson)

翻译自: https://www.javacodegeeks.com/2020/10/extend-hibernate-to-handle-java-stream-queries.html

hibernate