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的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 摩托罗拉e6刷机包(摩托罗拉e680i刷
- 下一篇: 怎样进入路由器设置界面【图】