日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java14:使用Java 14的新记录联接数据库表

發布時間:2023/12/3 java 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java14:使用Java 14的新记录联接数据库表 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

您是否知道可以使用Java 14的預覽記錄功能將數據庫表連接到Java Stream中? 閱讀這篇簡短的文章,并了解如何使用Speedment Stream ORM完成它。 我們將從如何設置您的項目開始。

設定

下載Java 14 。 轉到Speedment Initializer并下載您的項目骨架(包括pom.xml )。 修改您的以下行
pom.xml文件:

< maven.compiler.source >14</ maven.compiler.source > < maven.compiler.target >14</ maven.compiler.target > ... < plugin > < artifactId >maven-compiler-plugin</ artifactId > < version >3.8.1</ version > < configuration > < release >14</ release > < compilerArgs > --enable-preview </ compilerArgs > </ configuration > </ plugin >

確保您擁有支持新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的新记录联接数据库表的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。