Java14:使用Java 14的新记录联接数据库表
您是否知道可以使用Java 14的預(yù)覽記錄功能將數(shù)據(jù)庫(kù)表連接到Java Stream中? 閱讀這篇簡(jiǎn)短的文章,并了解如何使用Speedment Stream ORM完成它。 我們將從如何設(shè)置您的項(xiàng)目開(kāi)始。
設(shè)定
下載Java 14 。 轉(zhuǎn)到Speedment Initializer并下載您的項(xiàng)目骨架(包括pom.xml )。 修改您的以下行
pom.xml文件:
確保您擁有支持新Java 14功能的最新版本的ide(例如IDEA 2010.1)。
加速加入
速度允許將動(dòng)態(tài)JOIN:ed數(shù)據(jù)庫(kù)表作為標(biāo)準(zhǔn)Java流使用。 在本文中,我們將使用示例性的Sakila數(shù)據(jù)庫(kù),其中包含電影,演員,語(yǔ)言等。下載Sakila
這里還是搶泊塢版本在這里 。
借助Speedment,可以輕松地將表,視圖和聯(lián)接轉(zhuǎn)換為標(biāo)準(zhǔn)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()) );這將產(chǎn)生以下輸出:
ACADEMY DINOSAUR is in English ACE GOLDFINGER is in English ADAPTATION HOLES is in English ...代碼分解
from()方法獲取我們要使用的第一個(gè)表( Film )。 的
innerJoinOn()方法采用我們要連接的第二張表的特定列。 然后, equal()方法從我們要用作連接條件的第一個(gè)表中獲取一列。 因此,在此示例中,我們將獲得匹配的Film和Language實(shí)體,其中Language.LANGUAGE_ID列等于Film.LANGUAGE_ID 。
最后, build()將構(gòu)造我們的Join對(duì)象,該對(duì)象又可以用于創(chuàng)建Java Streams。 Join對(duì)象可以反復(fù)使用。
請(qǐng)注意, record FilmLanguage的構(gòu)造函數(shù)是如何在
build()方法。 還請(qǐng)注意如何從記錄中獲取電影和語(yǔ)言實(shí)體(例如filmLanguage.film() )。 與以前的Java版本相比,這是一個(gè)很大的改進(jìn),在Java版本中,我們不得不提供較長(zhǎng)的自定義類,或者使用具有訪問(wèn)器的元組get0()如get0()和get0() get1()而不是更具描述性的film()和language()
JOIN的類型和條件
我們可以使用innerJoinOn() leftJoinOn() rightJoinOn()和crossJoin()和表可以使用的條件被接合equal() notEqual() lessThan() lessOrEqual() greaterThan()和lessOrEqual()
下一步是什么?
在此處下載開(kāi)源Java 14。
在此處下載Speedment。
閱讀Speedment用戶指南中有關(guān)JOIN功能的所有內(nèi)容。
翻譯自: https://www.javacodegeeks.com/2020/02/java14-join-database-tables-with-java-14s-new-record.html
總結(jié)
以上是生活随笔為你收集整理的Java14:使用Java 14的新记录联接数据库表的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 花灯怎么做 制作的步骤是什么
- 下一篇: Java 8 Stream中间操作(方法