与任何编程语言一样,Java有多种工具可以轻松地在语言和数据库之间进行集成。有几种工具,例如Hibernate,Eclipse Link,JPA规范等等。但是,ORM带来了几个问题,有时使用它,然后再将其用于Java Communication层或JDBC并不有意义。本教程将介绍一种使用Spring JDBC模板简化JDBC代码的方法。
诸如ORM之类的映射框架减少了很多样板,减少了重复的代码,避免了错误,并且没有重新发明轮子。但是,当RDBMS由以面向对象的编程语言编写的应用程序提供服务时,经常会遇到对象关系阻抗不匹配的问题,这会带来一系列概念上和技术上的困难。
一个解决方案可能使用JDBC,但是它增加了处理数据和Java的复杂性。应用程序如何减少JDBC的冗长性?Spring JDBCTemplate是一种强大的机制,可以连接到数据库并执行SQL查询。它在内部使用JDBC API,但消除了JDBC API的许多问题。
从Spring Initializr开始
此示例应用程序将结合使用JDBCTemplate和Spring来使用两个数据库:PostgreSQL用于运行该应用程序和H2在测试范围内。对于所有Spring应用程序,您应该从Spring Initializr开始。Initializr提供了一种快速的方法来提取应用程序所需的所有依赖项,并为您完成了许多设置。此示例需要JDBC API,Spring MVC,PostgreSQL驱动程序和H2数据库依赖项。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
下一步是Car实体,其中包含五个字段:id,名称,城市,型号和颜色。在这个项目中,作为贫血模型的POJO足以应付它。丰富的模型可以保证对象的规则并避免任何封装问题,因此,它是防弹API。但是,它仅适用于复杂的项目。突出显示:当我们谈论软件体系结构时,“取决于”始终是一个很好的答案。
public class Car {
private Long id;
private String name;
private String city;
private String model;
private String color;
//...
public static CarBuilder builder() {
return new CarBuilder();
}
}
为了在Java和JDBC的ResultSet之间实现紧密集成,Spring JDBC具有RowMapper接口。开发人员可以创建一个自定义类,也可以使用BeanPropertyRowMapper,从而减少了样板。但是,该实体应具有公共获取者和设置者;除了提供便利而不是高性能之外,它可能还会遇到封装问题。为了获得最佳性能,请考虑使用自定义RowMapper实现。
public class CarRowMapper implements RowMapper<Car> {
@Override
public Car mapRow(ResultSet resultSet, int rowNum) throws SQLException {
Long id = resultSet.getLong("ID");
String name = resultSet.getString("name")