java联接pg库_Java14:使用Java 14的新记录联接数据库表
java聯(lián)接pg庫(kù)
您是否知道可以使用Java 14的預(yù)覽記錄功能將數(shù)據(jù)庫(kù)表連接到Java Stream中? 閱讀這篇簡(jiǎn)短的文章,并了解如何使用Speedment Stream ORM完成它。 我們將從如何設(shè)置您的項(xiàng)目開(kāi)始。
建立
下載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()方法從我們要用作聯(lián)接條件的第一個(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()方法。 還要注意如何從記錄中獲取電影和語(yǔ)言實(shí)體(例如filmLanguage.film() )。 這比以前的Java版本,我們必須提供相當(dāng)長(zhǎng)的自定義類或使用元組就像訪問(wèn)一個(gè)很大的進(jìn)步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
java聯(lián)接pg庫(kù)
總結(jié)
以上是生活随笔為你收集整理的java联接pg库_Java14:使用Java 14的新记录联接数据库表的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: ipad可以打电话吗
- 下一篇: java 轻量级文件数据库_Java:如