`
OneAPM_Official
  • 浏览: 25133 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java 8:如何使用流方式查询数据库?

阅读更多

Speedment 是使用 ORM 方式操作数据库的一种选择,以前我们需要100行操作数据库的 Java 代码,在 Java 8中,可能只需要一行代码。

在90年代末,我使用 Java 开发数据库应用的时候,许多代码逻辑都需要自己来编写,比如捕获异常、类型转换等,经过许多改动,最后这些代码变得难以维护和扩展。

Java 8:如何使用流方式查询数据库?

由于关系型数据库操作语言和面向对象语言之间的差异,如今我们仍然需要花费许多时间建立数据库与 Java 应用之间互相沟通的桥梁。通常,我们可以编写自己的映射层(mapping layer),或者使用第三方的 ORM(Object Relational Mapper)对象关系映射框架,比如 Hibernate。ORM 框架虽然使用起来很方便,但是如何正确地配置和提高框架操作数据库的性能却不太容易,ORM 框架往往会使我们的应用性能下降。

最近,我贡献了一个新的开源项目——Speedment,它能使我们使用 Java 8 开发数据库应用程序变得更为快捷和高效。

 

Speedment 是什么?

Speedment 是一个开源项目,它是一个基于 Java 8 的新特性开发的新的 Java 库,从这个项目开发开始,它的代码就全部使用 Java 8来编写。Speedment 使用标准流查询数据库,这使得开发者不需要学习任何新的查询 API ,以及不必考虑 JDBC 、ResultSet 和其他有关数据库的指定的操作。

Speedment 会根据现有数据库来自动生成代码。由于它的这种方式,开发者不需要编写一行关于数据库实体(database entities)的代码。它生成的代码中也包含 JavaDocs 帮助文档,这使开发者不需要编写关于 User 或者 Book 等对象的实体类。取而代之地,我们只需要创建或者使用一个现有的数据库,然后用 Speedment 去连接它,接着 Speedment 会分析数据库结构来生成实体类的代码。

更有趣的是,Speedment 用野兔来作为它的吉祥物。 
在接下来的例子中,我们会使用一个名为 “hare” 的数据库来给大家演示 Speedment 的使用方式。该数据库的表结构如下:

 

mysql> explain hare;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| id    | int(11)     | NO   | PRI | NULL    | auto_increment |
| name  | varchar(45) | NO   |     | NULL    |                |
| color | varchar(45) | NO   |     | NULL    |                |
| age   | int(11)     | NO   |     | NULL    |                |
+-------+-------------+------+-----+---------+----------------+
4 rows in set (0.01 sec)

 

 

下面是 Speedment 根据数据库信息生成的一个相应的实体类(为简洁起见,我们将 JavaDocs 在这里移除了):

 

public interface Hare extends Entity<Hare> {
    public final static ReferenceComparableField<Hare, Integer> ID = new ReferenceComparableFieldImpl<>("id", Hare::getId, Hare::setId);
    public final static ReferenceComparableStringField<Hare> NAME = new ReferenceComparableStringFieldImpl<>("name", Hare::getName, Hare::setName);
    public final static ReferenceComparableStringField<Hare> COLOR = new ReferenceComparableStringFieldImpl<>("color", Hare::getColor, Hare::setColor);
    public final static ReferenceComparableField<Hare, Integer> AGE = new ReferenceComparableFieldImpl<>("age", Hare::getAge, Hare::setAge);
    Integer getId();
    String getName();
    String getColor();
    Integer getAge();
    Hare setId(Integer id);
    Hare setName(String name);
    Hare setColor(String color);
    Hare setAge(Integer age);
    /** Graph-like traversal methods eliminating JOINs */
    Stream<Carrot> findCarrotsByOwner();
    Stream<Carrot> findCarrotsByRival();
    Stream<Carrot> findCarrots();
}

 

 

我将用一篇单独的文章介绍 find*() 方法的用法,它可以被用来代替 SQL joins 操作。

 

Queries查询示例

下面的例子展示如何查询 Hare 表的数据库信息:

 

List<Hare> oldHares = hares.stream()
    .filter(AGE.greaterThan(8))
    .collect(toList());

 

 

 

智能流

上面的代码看起来已经遍历了 hare 数据库表的所有行,但实际上并不是这样的。 Stream 是智能的,当它到达 collect() 操作的时候,会分析 filter 操作,并推断出 hare.age 大于8的列,因此会节省 hares 的流操作,产生与 “select * from hare where age > 8” 操作一样的效果。如果你使用了多个 filters,他们会被合并起来以节省流操作。下面是另一种用流方式进行多个操作的例子:

long noOldHares = hares.stream()
    .filter(AGE.greaterThan(8))
    .mapToInt(Hare::getAge)
    .sorted()
    .count();

 

在上面的代码中,当流到达 count() 操作时,它将检查它自己的管道。首先会推断上面例子中的 AGE 操作,其次在不改变 count() 结果的情况下,会推断 mapToInt() 和 sorted() 操作,这些操作可以被消除,因此这段代码的操作被节省为 “select count(*) from hare where age > 8”。这意味着您可以使用 Java 8 流而你不必如此在意流是如何转换为SQL的。

 

如何下载和加入我们

如果你想学习如何使用 Speedment 的 API 和在项目中如何使用 Speedment,可以访问网址 www.speedment.org,并可以在 gitter 上发表评论,也可以从 GitHub 上下载 Speedment 的源码,来贡献你自己的代码。

 

总结

回顾早期的一些老项目,一个超过100行代码的数据库类,现在可以使用 Java 8 缩减成1行代码。那是反转后的摩尔定律,在14年内(=7摩尔周期),行数大约减半了七次。这就是进步!

(编译自:https://dzone.com/articles/java-8-query-databases-using-streams

OneAPM 为您提供端到端的 Java 应用性能解决方案,我们支持所有常见的 Java 框架及应用服务器,助您快速发现系统瓶颈,定位异常根本原因。分钟级部署,即刻体验,Java 监控从来没有如此简单。想阅读更多技术文章,请访问 OneAPM 官方技术博客

本文转自 OneAPM 官方博客

分享到:
评论

相关推荐

    Java8中使用流方式查询数据库的方法

    在数据库查询方面,Java8的流API可以与ORM框架结合,提供更加高效和简洁的查询方式。本文将探讨如何在Java8中使用流查询数据库,特别是通过Speedment这个开源项目来实现这一目标。 Speedment是一个基于Java 8的新...

    java工具类:java连接各个数据库方法.java

    以上就是如何使用Java工具类连接各种不同类型的数据库的方法。这些代码示例可以帮助开发者快速建立起与数据库之间的连接,从而进行后续的数据操作。当然,实际开发过程中还需要根据具体的环境和需求对上述代码进行...

    Java实习报告:通过JDBC方式操作数据库(带实例和代码).doc

    【Java实习报告:通过JDBC方式操作数据库】 在Java编程中,JDBC(Java Database Connectivity)是Java标准API,用于连接Java应用程序与各种类型的数据库。本实习报告将深入探讨如何使用JDBC进行数据库操作,包括增...

    Speedment一个数据库访问库它利用了Java8StreamAPI进行查询

    总之,Speedment是一个强大的数据库访问库,通过结合Java 8的Stream API,它提供了高效、灵活且易于使用的数据库操作方式。对于Java开发者来说,掌握Speedment可以帮助他们更轻松地处理数据库相关的任务,同时提升...

    【经典】Java数据库编程 JAVA跟数据库连接源代码

    本教程主要关注Java如何与数据库进行交互,特别是使用JDBC(Java Database Connectivity)进行连接和操作。以下是对各个知识点的详细阐述: 1. **数据库连接方式与JDBC**: JDBC是Java中用于访问数据库的标准接口...

    java链接数据库大全

    JDBC的核心作用在于它允许Java程序通过统一的方式与不同的数据库系统进行交互,从而简化了数据库操作的复杂度。 #### 二、JDBC基本概念 在深入讨论如何使用JDBC与不同类型的数据库建立连接之前,我们先了解几个...

    Java典型应用彻查1000例-数据库应用基础

    这本书深入浅出地讲解了Java在数据库应用中的核心概念和常见实践,旨在帮助读者掌握如何高效、安全地使用Java进行数据库操作。 在Java编程中,数据库应用是不可或缺的一部分,尤其是在企业级应用开发中。本书涵盖了...

    基于Java的数据库应用框架的研究设计

    例如,通过优化数据库查询、使用缓存策略、负载均衡等技术,可以提升网络教学平台的性能和可用性。 网络教学平台的建设和应用部分虽然不是Java数据库框架的直接讨论,但可以作为背景,说明Java技术在教育领域的实际...

    java存取图片到数据库

    对于Base64编码,可以使用Java 8及以后版本的`java.util.Base64`类进行编码。 2. 数据库准备: 创建一个合适的数据库表来存储图片数据。表中至少需要一个字段用于存储图片数据,可以是一个BLOB(Binary Large ...

    JAVA数据库大全.docx

    JDBC 提供了一个标准的 API,使得工具/数据库开发人员可以使用纯 Java API 来编写数据库应用程序。然而,各个开发商的接口并不完全相同,因此在不同的开发环境中可能需要进行配置变化。 一、JDBC简介 JDBC 是 Java...

    将图片以字节流存到数据库再从数据库获取显示

    例如,在Java中,可以使用`java.io.FileInputStream`和`java.nio`包中的`ByteBuffer`来读取图片文件,并将内容转化为字节流。 ```java File file = new File("image.jpg"); FileInputStream fis = new ...

    java读取纯真IP地址数据库

    总的来说,读取纯真IP地址数据库需要理解数据库的结构,选择合适的I/O流进行读取,使用适当的解码方式处理字符串,同时利用高效的查找算法实现快速定位。在整个过程中,错误处理和性能优化也是不可忽视的部分。

    java与不同数据库的连接

    Hibernate是流行的JPA实现,它将Java对象映射到数据库记录,使得开发者可以使用面向对象的方式处理数据。 3. MyBatis:MyBatis是一个轻量级的框架,它允许开发者编写SQL语句并将其与Java代码集成,提供了一种半...

    java数据库课程设计之学生信息管理系统

    - 在这个系统中,Java用于编写用户界面和业务逻辑,可能使用Swing或JavaFX构建图形用户界面,同时通过Java的JDBC(Java Database Connectivity)API来与数据库进行交互。 2. **数据库管理**: - 数据库是存储和...

    Java对数据库编程.pdf

    4. **本地协议纯Java驱动方式:**使用本地数据库协议进行通信,但驱动程序本身是纯Java实现。这种方式提供了更高的性能和安全性,因为所有操作都在Java虚拟机内完成。 #### 四、总结 本文档详细介绍了如何使用Java...

    java数据库开发案例精选

    在“Java数据库开发案例精选”中,我们主要探讨的是如何使用Java编程语言与各种数据库进行交互,实现数据的存储、查询、更新和删除等操作。Java数据库开发是软件开发中的重要组成部分,尤其在构建Web应用、企业级...

    java于各种数据库连接额语句

    在Java开发过程中,经常需要与不同的数据库进行交互以完成数据存储、查询等操作。下面将详细介绍如何通过Java语言连接八种常见数据库的方法及代码示例。 #### 1. Oracle 8/8i/9i数据库连接 为了连接Oracle数据库,...

    java生成数据库字典表mysql doc-generator

    Java生成数据库字典表MySQL Doc-Generator是一款实用的工具,旨在帮助开发者将MySQL数据库中的表结构信息导出为Word文档,方便进行数据库设计文档的整理和分享。这个工具简化了手动编写数据库字典表的过程,提高了...

    Java自定义的类似ORM的数据库操作框架

    Java自定义的类似ORM的数据库操作框架是一种高效且灵活的数据访问解决方案,旨在简化数据库的交互过程,类似于流行的ORM(对象关系映射)框架,如Hibernate和MyBatis。ORM框架的核心理念是将数据库操作转化为面向...

    Java数据库编程宝典

    8. Spring JDBC与JPA:在Spring框架中,Spring JDBC提供了一种简化JDBC使用的抽象层,而Java Persistence API (JPA)结合Hibernate等实现,提供了面向对象的数据库编程方式。 9. 数据库优化:包括SQL查询优化、索引...

Global site tag (gtag.js) - Google Analytics