Java14:使用Java 14的新记录联接数据库表
您是否知道可以使用Java 14的預覽記錄功能將數據庫表連接到Java Stream中? 閱讀這篇簡短的文章,并了解如何使用Speedment Stream ORM完成它。 我們將從如何設置您的項目開始。
設定
下載Java 14 。 轉到Speedment Initializer并下載您的項目骨架(包括pom.xml )。 修改您的以下行
pom.xml文件:
確保您擁有支持新Java 14功能的最新版本的ide(例如IDEA 2010.1)。
加速加入
速度允許將動態JOIN:ed數據庫表作為標準Java流使用。 在本文中,我們將使用示例性的Sakila數據庫,其中包含電影,演員,語言等。下載Sakila
這里還是搶泊塢版本在這里 。
借助Speedment,可以輕松地將表,視圖和聯接轉換為標準Java流。 這就是在Java 14中的樣子:
var speedment = new SakilaApplicationBuilder() .withPassword( "sakila" ) .withBundle(JoinBundle. class ) .build(); var joinComponent = speedment.getOrThrow(JoinComponent. class ); var films = speedment.getOrThrow(FilmManager. class ); // Define a Java 14 "record" that can hold a Film and a Language record FilmLanguage(Film film, Language language) {} var join = joinComponent.from(films.getTableIdentifier()) .leftJoinOn(Language.LANGUAGE_ID).equal(Film.LANGUAGE_ID) // Provide the constructor of the Java 14 "record" // to be used to construct Film/Language composites .build(FilmLanguage:: new ); join.stream() .forEach(filmLanguage -> System.out.format( "%s is in %s%n" , filmLanguage.film().getTitle(), filmLanguage.language().getName()) );這將產生以下輸出:
ACADEMY DINOSAUR is in English ACE GOLDFINGER is in English ADAPTATION HOLES is in English ...代碼分解
from()方法獲取我們要使用的第一個表( Film )。 的
innerJoinOn()方法采用我們要連接的第二張表的特定列。 然后, equal()方法從我們要用作連接條件的第一個表中獲取一列。 因此,在此示例中,我們將獲得匹配的Film和Language實體,其中Language.LANGUAGE_ID列等于Film.LANGUAGE_ID 。
最后, build()將構造我們的Join對象,該對象又可以用于創建Java Streams。 Join對象可以反復使用。
請注意, record FilmLanguage的構造函數是如何在
build()方法。 還請注意如何從記錄中獲取電影和語言實體(例如filmLanguage.film() )。 與以前的Java版本相比,這是一個很大的改進,在Java版本中,我們不得不提供較長的自定義類,或者使用具有訪問器的元組get0()如get0()和get0() get1()而不是更具描述性的film()和language()
JOIN的類型和條件
我們可以使用innerJoinOn() leftJoinOn() rightJoinOn()和crossJoin()和表可以使用的條件被接合equal() notEqual() lessThan() lessOrEqual() greaterThan()和lessOrEqual()
下一步是什么?
在此處下載開源Java 14。
在此處下載Speedment。
閱讀Speedment用戶指南中有關JOIN功能的所有內容。
翻譯自: https://www.javacodegeeks.com/2020/02/java14-join-database-tables-with-java-14s-new-record.html
總結
以上是生活随笔為你收集整理的Java14:使用Java 14的新记录联接数据库表的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 花灯怎么做 制作的步骤是什么
- 下一篇: Java 8 Stream中间操作(方法