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