Java 11:JOIN表,获取Java流
是否曾經(jīng)想過如何將聯(lián)接的數(shù)據(jù)庫表轉(zhuǎn)換為Java Stream? 閱讀這篇簡短的文章,并了解如何使用Speedment Stream ORM完成它。 我們將從Java 8示例開始,然后研究Java 11的改進(jìn)。
Java 8和JOIN
速度允許將動(dòng)態(tài)JOIN:ed數(shù)據(jù)庫表作為標(biāo)準(zhǔn)Java流使用。 我們首先來看一個(gè)使用Sakila示例數(shù)據(jù)庫的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);這將產(chǎn)生以下輸出(經(jīng)過重新格式化并縮短了可讀性):
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編寫聯(lián)接更加容易。 我們不必顯式聲明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()方法獲取我們要使用的第一個(gè)表( Language )。 innerJoinOn()方法采用我們要連接的第二張表的特定列。 然后, equal()方法從我們要用作連接條件的第一個(gè)表中獲取一列。 因此,在此示例中,我們將獲得匹配的Language和Film實(shí)體,其中Film.LANGUAGE_ID列等于Language.LANGUAGE_ID 。
最后, build()將構(gòu)造我們的Join對(duì)象,該對(duì)象又可以用于創(chuàng)建Java Streams。 Join對(duì)象可以反復(fù)使用。
JOIN的類型和條件
我們可以使用innerJoinOn() leftJoinOn() rightJoinOn()和crossJoin()和表可以使用的條件被接合equal() notEqual() lessThan() lessOrEqual() greaterThan()和lessOrEqual()
下一步是什么?
在此處下載開源Java 11。
在此處下載Speedment。
閱讀Speedment用戶指南中有關(guān)JOIN功能的所有內(nèi)容。
翻譯自: https://www.javacodegeeks.com/2018/12/java-11-join-tables-java-streams.html
總結(jié)
以上是生活随笔為你收集整理的Java 11:JOIN表,获取Java流的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 马斯克考虑向所有X/Twitter用户收
- 下一篇: aes256加密java_使用Java和