Java 持久层概述

简介: Java Database Connectivity 是一系列接口规范。Java 程序都是通过 JDBC 连接数据库的、然后通过其执行SQL、对数据库进行操作。DBC 只是 Sun 公司定义的接口规范、具体实现是交由各个数据库厂商去实现的、因为每个数据库都有其特殊性、这些是 Java 规范没办法确定的

网络异常,图片无法展示
|


JDBC


Java Database Connectivity 是一系列接口规范。Java 程序都是通过 JDBC 连接数据库的、然后通过其执行SQL、对数据库进行操作。


DBC 只是 Sun 公司定义的接口规范、具体实现是交由各个数据库厂商去实现的、因为每个数据库都有其特殊性、这些是 Java 规范没办法确定的

网络异常,图片无法展示
|

import java.sql.*;
 import java.util.logging.Level;
 import java.util.logging.Logger;
 public class JdbcExample {
     public static void main(String[] args) {
         JdbcExample example = new JdbcExample();
         Role role = example.getRole(1L);
         System.out.printf("role_name => " + role.getRoleName());
     }
     public Role getRole(Long id) {
         Connection connection = this.getConnection();
         PreparedStatement ps = null;
         ResultSet rs = null;
         try {
             // 操作 Connection,打开 Statement 对象
             ps = connection.prepareStatement("select id,role_name,note from t_role where id = ?");
             ps.setLong(1,id);
             // 通过 Statement 执行 SQL,返回结果到 ResultSet 对象
             rs = ps.executeQuery();
             // 通过 ResultSet 读取数据,然后通过代码转化为具体的 POJO 对象
             while (rs.next()){
                 Long roleId = rs.getLong("id");
                 String roleName = rs.getString("role_name");
                 String note = rs.getString("note");
                 Role role = new Role();
                 role.setId(id);
                 role.setRoleName(roleName);
                 role.setNote(note);
                 return role;
             }
         } catch (SQLException e) {
             Logger.getLogger(JdbcExample.class.getName()).log(Level.SEVERE,null,e);
         } finally {
             this.close(rs,ps,connection);
         }
         return null;
     }
     private Connection getConnection(){
         // 使用 JDBC 编程需要连接数据库,注册驱动和数据库信息
         Connection connection = null;
         try {
             Class.forName("com.mysql.jdbc.Driver");
             String url = "jdbc:mysql://localhost:3306/mybatis1?characterEncoding=utf8";
             String user = "root";
             String password = "root";
             connection = DriverManager.getConnection(url,user,password);
         } catch (ClassNotFoundException | SQLException e) {
             Logger.getLogger(JdbcExample.class.getName()).log(Level.SEVERE,null,e);
             return null;
         }
         return connection;
     }
     private void close(ResultSet rs,Statement stmt,Connection connection){
         // 关闭数据库相关资源
         try {
             if (rs != null && !rs.isClosed()){
                 rs.close();
             }
         } catch (SQLException e) {
             Logger.getLogger(JdbcExample.class.getName()).log(Level.SEVERE,null,e);
         }
         try {
             if (stmt != null && !stmt.isClosed()){
                 stmt.close();
             }
         } catch (SQLException e) {
             Logger.getLogger(JdbcExample.class.getName()).log(Level.SEVERE,null,e);
         }
         try {
             if (connection != null && !connection.isClosed()){
                 connection.close();
             }
         } catch (SQLException e) {
             Logger.getLogger(JdbcExample.class.getName()).log(Level.SEVERE,null,e);
         }
     }
 }
复制代码
  • 注册数据库驱动类,指定数据库地址,其中包括 DB 的用户名、密码及其他连接信息;
  • 调用 DriverManager.getConnection() 方法创建 Connection 连接到数据库;
  • 调用 Connection 的 createStatement() 或 prepareStatement() 方法,创建 Statement 对象,此时会指定 SQL(或是 SQL 语句模板 + SQL 参数);
  • 通过 Statement 对象执行 SQL 语句,得到 ResultSet 对象,也就是查询结果集;
  • 遍历 ResultSet,从结果集中读取数据,并将每一行数据库记录转换成一个 JavaBean 对象;
  • 关闭 ResultSet 结果集、Statement 对象及数据库 Connection,从而释放这些对象占用的底层资源。


ORM


ORM(Object Relational Mapping,对象-关系映射)框架来封装 1~6 步的重复性代码,实现对象模型、关系模型之间的转换。

网络异常,图片无法展示
|

网络异常,图片无法展示
|

常见的 ORM 框架 Mybatis、Hibernate


JPA


JPA 是在 JDK 5.0 后提出的 Java 持久化规范(JSR 338)。JPA 规范本身是为了整合市面上已有的 ORM 框架,结束 Hibernate、EclipseLink、JDO 等 ORM 框架各自为战的割裂局面,简化 Java 持久层开发。

网络异常,图片无法展示
|


Spring Data JPA


Spring Data JPA 是符合 JPA 规范的一个 Repository 层的实现

网络异常,图片无法展示
|


虽然市面上的绝大多数 ORM 框架都实现了 JPA 规范,但是它们在 JPA 基础上也有各自的发展和修改,这样导致我们在使用 JPA 的时候,依旧无法无缝切换底层的 ORM 框架实现。而使用 Spring Data JPA 时,由于Spring Data JPA 帮助我们抹平了各个 ORM 框架的差异,从而可以让我们的上层业务无缝地切换 ORM 实现框架。

目录
相关文章
|
6月前
|
IDE Oracle Java
java基础教程(1)-Java概述和相关名词解释
【4月更文挑战第1天】Java是1995年Sun Microsystems发布的高级编程语言,以其跨平台特性著名。它介于编译型和解释型语言之间,通过JVM实现“一次编写,到处运行”。Java有SE、EE和ME三个版本,分别针对标准、企业及嵌入式应用。JVM是Java虚拟机,确保代码在不同平台无需重编译。JRE是运行环境,而JDK包含开发工具。要安装Java开发环境,可从Oracle官网下载JDK,设置JAVA_HOME环境变量并添加到PATH。
|
6月前
|
网络协议 算法 Java
【Java网络编程】网络编程概述、UDP通信(DatagramPacket 与 DatagramSocket)
【Java网络编程】网络编程概述、UDP通信(DatagramPacket 与 DatagramSocket)
67 3
|
2月前
|
安全 Java API
Java 18 概述:新特性一览
Java 18 作为 Java 平台的最新版本,引入了多项令人振奋的新特性和改进,包括模式匹配、记录类型、流库改进、外部函数与内存 API 以及并发处理增强。这些新功能不仅提升了开发者的生产力,还显著增强了 Java 的性能和安全性。本文将详细介绍 Java 18 的主要新特性,并通过代码示例帮助读者更好地理解和应用这些功能。
|
3月前
|
存储 Oracle Java
01 Java概述基础与计算机基础(DOS+进制+原码反码补码)
01 Java概述基础与计算机基础(DOS+进制+原码反码补码)
41 17
|
3月前
|
存储 算法 Oracle
19 Java8概述(Java8概述+lambda表达式+函数式接口+方法引用+Stream+新时间API)
19 Java8概述(Java8概述+lambda表达式+函数式接口+方法引用+Stream+新时间API)
65 8
|
3月前
|
Java 数据安全/隐私保护
09 Java面向对象三大特征(概述)
09 Java面向对象三大特征(概述)
69 4
|
4月前
|
SQL 缓存 Java
使用MyBatis优化Java持久层操作
使用MyBatis优化Java持久层操作
|
5月前
|
设计模式 算法 Java
Java设计模式:核心概述(一)
Java设计模式:核心概述(一)
|
4月前
|
SQL 缓存 Java
使用MyBatis优化Java持久层操作
使用MyBatis优化Java持久层操作
|
6月前
|
安全 Java 编译器
Java第一课——Java详细图文概述
Java第一课——Java详细图文概述
57 6
Java第一课——Java详细图文概述