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

歡迎訪問 生活随笔!

生活随笔

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

java

Java 8 Friday Goodies:Lambda和SQL

發布時間:2023/12/3 java 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java 8 Friday Goodies:Lambda和SQL 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在 Data Geekery ,我們喜歡Java。 而且,由于我們真的很喜歡 jOOQ的流暢的API和查詢DSL ,我們對Java 8將為我們的生態系統帶來什么感到非常興奮。 我們已經 寫了一些關于Java 8好東西的博客 ,現在我們覺得是時候開始一個新的博客系列了……

Java 8星期五

每個星期五,我們都會向您展示一些不錯的教程風格的Java 8新功能,這些功能利用了lambda表達式,擴展方法和其他好東西。 您可以在GitHub上找到源代碼 。

Java 8 Goodie:Lambda和SQL

如果您習慣于編寫Groovy,這對您來說可能是“ so 2003”。 我們知道。 自成立以來,Groovy便知道一種非常有用的方式來編寫基于字符串的SQL。 這是用Groovy編寫的示例( 請參閱此處的官方文檔 ):

import groovy.sql.Sql sql = Sql.newInstance( 'jdbc:h2:~/test', 'sa', '', 'org.h2.Driver' ) sql.eachRow( 'select * from information_schema.schemata' ) { println "$it.SCHEMA_NAME -- $it.IS_DEFAULT" }

還要注意Groovy的內置String插值,您可以在其中將表達式放入字符串中。 但是,如果我們使用的是第三方庫而不是直接使用JDBC,那么我們在Java領域,并且在Java 8中,Java / SQL集成也會變得更好。

在以下示例中,我們正在研究如何使用這三個流行的庫從H2數據庫中獲取數據并將記錄映射到自定義POJO / DTO中:

  • OO (震驚,我知道)
  • Spring數據/ JDBC
  • Apache Commons DbUtils

與往常一樣, 這些資源也可以從GitHub獲得 。 對于這些測試,我們將創建一些POJO / DTO來包裝模式元信息:

class Schema {final String schemaName;final boolean isDefault;Schema(String schemaName, boolean isDefault) {this.schemaName = schemaName;this.isDefault = isDefault;}@Overridepublic String toString() {return "Schema{" +"schemaName='" + schemaName + '\'' +", isDefault=" + isDefault +'}';} }

我們的主要方法將通過DriverManager獲得H2連接:

Class.forName("org.h2.Driver"); try (Connection c = getConnection("jdbc:h2:~/test", "sa", "")) {String sql = "select schema_name, is_default "+"from information_schema.schemata "+"order by schema_name";// Library code here... }

現在,當使用基于字符串的SQL時,Java 8如何改進jOOQ API? 太好了! 查看以下小查詢:

DSL.using(c).fetch(sql).map(r -> new Schema(r.getValue("SCHEMA_NAME", String.class),r.getValue("IS_DEFAULT", boolean.class))).forEach(System.out::println);

這應該是這樣,對嗎? 請注意,jOOQ的本機API還能夠將數據庫Record直接映射到您的POJO上,例如:

DSL.using(c).fetch(sql).into(Schema.class).forEach(System.out::println);

使用Spring JDBC和RowMapper時,事情看起來同樣不錯(請注意,以下內容仍會引發已檢查的SQLException ):

new JdbcTemplate(new SingleConnectionDataSource(c, true)).query(sql, (rs, rowNum) -> new Schema(rs.getString("SCHEMA_NAME"),rs.getBoolean("IS_DEFAULT"))).forEach(System.out::println);

…如果您使用的是Apache DbUtils ,則可以執行幾乎相同的操作:

new QueryRunner().query(c, sql, new ArrayListHandler()).stream().map(array -> new Schema((String) array[0],(Boolean) array[1])).forEach(System.out::println);

結論

這三種解決方案或多或少都是等效的,并且非常精簡。 同樣,這里的要點是Java 8將改進所有現有的API。 接受SAM參數(單一抽象方法類型)的方法越明確(很少重載!),對于Java 8集成越好。

下周,我們將看到使用java.util.Map API時將大大改善的幾件事。

參考: Java 8 Friday Goodies:來自Java,CG和JOOQ博客的JCG合作伙伴 Lukas Eder的Lambda和SQL 。

翻譯自: https://www.javacodegeeks.com/2014/02/java-8-friday-goodies-lambdas-and-sql.html

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的Java 8 Friday Goodies:Lambda和SQL的全部內容,希望文章能夠幫你解決所遇到的問題。

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