Spring Boot 和 JDBCTemplate简介: JDBC Template

与任何编程语言一样,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")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值