Java 11:JOIN表,获取Java流
是否曾經想過如何將聯接的數據庫表轉換為Java Stream? 閱讀這篇簡短的文章,并了解如何使用Speedment Stream ORM完成它。 我們將從Java 8示例開始,然后研究Java 11的改進。
Java 8和JOIN
速度允許將動態JOIN:ed數據庫表作為標準Java流使用。 我們首先來看一個使用Sakila示例數據庫的Java 8解決方案:
Speedment app = ...;JoinComponent joinComponent = app.getOrThrow(JoinComponent.class);Join<Tuple2OfNullables<Language, Film>> join = joinComponent.from(LanguageManager.IDENTIFIER).innerJoinOn(Film.LANGUAGE_ID).equal(Language.LANGUAGE_ID).build();join.stream().forEach(System.out::println);這將產生以下輸出(經過重新格式化并縮短了可讀性):
Tuple2OfNullablesImpl {LanguageImpl { languageId = 1, name = English, ... }, FilmImpl { filmId = 1, title = ACADEMY DINOSAUR, ... } } Tuple2OfNullablesImpl {LanguageImpl { languageId = 1, name = English, ... }, FilmImpl { filmId = 2, title = ACE GOLDFINGER, ... } } Tuple2OfNullablesImpl {LanguageImpl { languageId = 1, name = English, ... },FilmImpl { filmId = 3, title = ADAPTATION HOLES, ... } } ...Java 11和JOIN
在新的Java版本11中,存在Local-Variable-Type-Inference(又稱var聲明),這使得使用Speedment編寫聯接更加容易。 我們不必顯式聲明join變量的類型:
Speedment app = ...;JoinComponent joinComponent = app.getOrThrow(JoinComponent.class);var join = joinComponent.from(LanguageManager.IDENTIFIER).innerJoinOn(Film.LANGUAGE_ID).equal(Language.LANGUAGE_ID).build();join.stream().forEach(System.out::println);代碼分解
from()方法獲取我們要使用的第一個表( Language )。 innerJoinOn()方法采用我們要連接的第二張表的特定列。 然后, equal()方法從我們要用作連接條件的第一個表中獲取一列。 因此,在此示例中,我們將獲得匹配的Language和Film實體,其中Film.LANGUAGE_ID列等于Language.LANGUAGE_ID 。
最后, build()將構造我們的Join對象,該對象又可以用于創建Java Streams。 Join對象可以反復使用。
JOIN的類型和條件
我們可以使用innerJoinOn() leftJoinOn() rightJoinOn()和crossJoin()和表可以使用的條件被接合equal() notEqual() lessThan() lessOrEqual() greaterThan()和lessOrEqual()
下一步是什么?
在此處下載開源Java 11。
在此處下載Speedment。
閱讀Speedment用戶指南中有關JOIN功能的所有內容。
翻譯自: https://www.javacodegeeks.com/2018/12/java-11-join-tables-java-streams.html
總結
以上是生活随笔為你收集整理的Java 11:JOIN表,获取Java流的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 马斯克考虑向所有X/Twitter用户收
- 下一篇: input发送a.jax_JAX-RS