章节索引 :

Hibernate 简介

图片描述

图片来自 Hibernate 官网

1. 前言

大家好!本节课将和大家一起学习鼎鼎有名的 Hibernate 框架

本节课程将向大家介绍:

  • Hibernate 的功能 、特点;
  • Hibernate 产生的背景;
  • 并初步探讨编写 Jdbc 框架的基础构建思路。

2. Hibernate 是什么

简而言之:

  • Hibernate 是一个 Java Jdbc 框架,用来简化 Java Jdbc 操作;
  • Hibernate 也是一个ORM 框架,可以自动完成关系数据库中关系型数据到 Java 对象型数据的映射;
  • 当然,还可以说是一个持久化框架

以上说法其实是对完成同一件事情不同角度的诠释。

Hibernate 的出现就是想让开发者的编码工作变得简单,这个简单指不需要在非核心逻辑编写上花费太多时间。

3. Hibernate 的发展历史

喝水不忘挖井人,先了解下 Hibernate 的发展历程。

故事的大致情节就是澳大利亚墨尔本一位名为 Gavin King 的 27 岁的程序员嫌弃原有的 Jdbc 编码工作方式太过无聊、无脑。于是就买了一本 SQL 编程的书籍在不长的时间内写了这么一个叫 Hibernate 的框架。

Hibernate 一出江湖,便一鸣惊人如此而已;
Hibernate 承载了一个程序员的励志故事。
Hibernate 由最初的 1.0 版本演变到了现在 6.x 版本(官网最新显示),功能越来越强大,体积当然也越来越强大。
至于你爱不爱它,还是要看项目的需要。
故事讲完,继续!

4. Hibernate 的特点

Hibernate 类似的框架很多,比如 Mybatis 之类。但是 Hibernate 在江湖上的地位一直都比较稳定,追捧之人众多。当然,各喜所爱!在每一个程序员的心里都会有自己的白马王子。

Hibernate 特点如下:

  • 完全面向对象操作: 操作过程可以忘记 Jdbc API 带来的伤痛;
  • 操作简单: 复杂的查询也只需几行代码,可以全身心去做核心业务逻辑;
  • 没有反射就没有框架: 操作简单的代价是底层封装代码的负重前行,Hibernate 适合业务逻辑复杂的场景,不适合数据量很大的应用;
  • Hibetnate 提供了专业级生产环境中的事务、缓存、并发等多种容错、高性能、高稳定性的解决方案。产品上线后,可减少开发者的后顾之忧,不用担心什么时候会有只 Bug 突然爬出来;
  • 简单易学,操作方便,学习成本较低。还有……还有……就是 Hiberate 提供一种框架设计思想,其开发理念对开发者可产生思想层面影响。

5. Hibernate 与其它框架的比较

  • 更适合现代开发理念: 产品的生命周期决定产品的市场价值,快速迭代开发是主流。Hibernate 能让开发者高度关注项目的核心业务逻辑,而不因重复繁杂的数据库连接操作影响产品的迭代周期;

  • 说到 Hibetnate,就会谈到与之齐名的 MyBatisMyBatis 以半开发模式吸引开发者,让开发者在开发过程具有一定的把控感。但是,在数据库操作大的情况下书写SQL语句并不是一件轻松之事;对业务量多、数据库操作相对较少的情况,书写些常规性SQL想必也带来不了成就感。不如 Hibernate 来的简单直接;

  • Hibernate 提供多元化的操作模式。纯粹主义者能以完全面向对象方式操作;Hibernate 也提供了原生SQL操作模式,适合对原生 SQL 语句钟情者;对于复杂的数据操作,也支持存储过程调用。应有尽有,总能找到自己喜欢的感觉。

专业的角度,无论哪一种 Jdbc 框架,其要解决的问题都是一样的,其核心原则和思想是一样的。Hibetnate 是一个封装的严丝合缝的开源框架,其内在的代码架构代码实现模式对于学习者无疑是一座宝藏。这点其它框架就无法与其一比。

6. Jdbc 框架形成过程

6.1 什么是持久化

要真正了解、认识 Hibernate, 先切换一下镜头,回到没有Hibernate 之前的世界,一起来了解框架的演变过程(有需求才会有市场嘛)。

现在是提问时间:

程序的本质是什么?

-----------------------我是等待你答案的中划线-----------------------

程序的本质是解决现实中的问题,解决问题之前,先解决第一个问题,用计算机建模并保存现实生活中的信息,这个过程叫信息数据化

然后,按需求对数据进行逻辑处理并产生结果数据。程序是从数据到数据的过程,当然,算法功底很重要。

程序运行时的数据是保存在内存中的,叫临时数据或叫瞬时数据

程序运行过程产生的数据有些是需要永久性保存的,选择介质较多,一般会选择保存在数据库中,Java 程序员可以使用 Jdbc Api 和数据库进行交互。

把程序中的数据写回数据库这个过程也可称为数据持久化过程。

6.2 Java Jdbc 框架演变之路

先回顾一下纯手工 Jdbc 操作流程:

  1. 加载由不同厂商遵循 Jdbc 规范开发的驱动类。关于 Jdbc 驱动类开发不是这里要讲的,可查阅相关资料;
Class.forName("对应数据库的驱动类名");
  1. 建立 Java 程序和数据库系统的连接。本质是进程和进程的网络连接;
Connection conn = DriverManager.getConnection("url","用户名","密码");
  1. 确定数据清单。数据库只认 SQL 语句,你需要数据库帮你做什么样的数据操作,需要传送 SQL 指令给数据库;
String sql="使用sql语法描述数据需求";
  1. 需要一个信使。创建一个语句处理对象充当信使,任务就是上传下达;
PreparedStatement preparedStatement=conn.prepareStatement(sql); 
  1. 信使工作,把程序中的数据搬运到数据库,或把数据库数据搬运到程序;
preparedStatement.各种方法();
  1. 数据搬运过来后,Java 代码要用呀!Java 语言有什么特点?面向对象吗?搬运过来的数据是符合关系数据库特点的数据,于是开始手工数据格式转换、封装;

省略若干代码,心里希望表结构中字段不要太多!此时的苦只有自己知道!!
7. 最后把封装成 OOP 的数据交付给 Java 业务代码使用,各种资源关闭。

在编码时,只要涉及到和数据交互行为。好吧,把前面的几个步骤再走一遍。发现没有,其实你在做大量的重复工作,好好的脑力活生生变成了体力活。

怎么办?难道要承受这种编程生活的折磨吗,当然不!

通过模板方法解决 Jdbc 访问中的重复性问题。

其实,Jdbc 编程是一个模板化的操作过程,针对不同的数据请求操作其中只有 2 个地方是不一样的。

  • 数据清单不一样。每一次、不同数据需求的 Jdbc 操作请求,SQL 语句是不一样的。
  • 另一个不一样是从关系数据库中读出来的数据封装成对应的目标对象类型是不一样的。

知道这些就好办,可以把 Jdbc 代码操作封装成一个模板方法。在模板方法中预留 2 个参数:

  • 传入 SQL 语句;
  • 传入一个用于封装结果集中的数据到 OOP 对象的方法。

按照这个思路,属于你的 Jdbc 简易框架就要诞生了。有点激动吧!

如下是查询模板方法代码参考:

/**
 *通用 jdbc 查询数据模板方法
 *connection:连接对象,可由外部传入,也可由内部方法创建
 *sql:传过来的 SQL语句
 *rsh:自定义结果集处理接口,其中有封装结果集数据的方法
 *args:SQL中参数值
 */
public <T> T query(Connection connection, String sql, ResultSetHandler<T> rsh, Object... args) throws SQLException {
   // 建立连接
   if (connection == null)
    	connection = this.dataSource.getConnection();
    if (sql == null)
    	throw new SQLException("SQL语句不正确");
    // 预处理语句
    PreparedStatement preStatement = connection.prepareStatement(sql);
    // SQL指定参数值
    fillStatement(preStatement, args);
    // 结果集
    ResultSet rs = preStatement.executeQuery();
    // 结果处理规范
    T result = rsh.handle(rs);
    // 资源关闭
    this.close(connection, preStatement, rs);
    return result;
}

调用上面方法时,传递一条 SQL 语句,传递一个实现了 ResultSetHandler 接口的对象(此对象提供方法完成数据映射工作)就可以了。

我们编写的模板方法与 Hibernate 相比较:

  • Hibernate 会自动构建生成 SQL 语句。复杂的 SQL 也不是问题;
  • 自动完成了关系型数据库中的数据到 Java 对象的封装

所以说Hibernate 是一个全自动化的 ORM 持久化框架。

当然 Hibernate 可不仅只完成数据库数据的访问,还会考虑性能、事务等生产环境中的诸多现实问题,这些会在本课程后面慢慢展开。

7. 学习基础

学习 Hibernate 分 2 个层次:

  • Hibernate 当成一个工具, 掌握其应用。只需要学习者具有一定的 JAVA 基础知识即可;
  • 了解 Hibernate 底层运行机制,对其运行过程进行调优,则需要学习者具有反射、网络编程、多线程等相关知识的储备。

8. 小结

好了!到了总结时间:

本章节帮助大家初步了解 Hibernate 框架的作用。和原生态Jdbc 操作相比较,可发现 Hibernate 解决了 Jdbc 操作中的 SQL 语句生成问题、关系数据库中数据自动映射问题。

Hibernate通过提供统一的接口方式让用户以面向对象的方式透明的、简单地使用Jdbc连接数据库

让开发者从繁琐无太多技术含量的编码中解脱出来,用更多的心思和时间完成核心业务逻辑。