Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。

使用Hibernate进行数据库持久化操作
Hibernate 是一个开源的对象关系映射(Object-Relational Mapping,简称 ORM)框架,它对 JDBC 进行了封装,将数据库中的表和 Java 中的对象进行映射,使得开发者可以通过操作对象的方式来实现对数据库的操作。本文将介绍 Hibernate 的基本概念和使用方法,帮助读者掌握如何使用 Hibernate 进行数据库持久化操作。
一、Hibernate 简介
Hibernate 是一种 ORM 框架,它允许开发者将数据库中的表和 Java 中的对象进行映射,从而简化了数据库操作。通过 Hibernate,开发者无需编写繁琐的 SQL 语句,只需操作 Java 对象即可实现对数据库的增删改查等操作。Hibernate 支持多种数据库系统,如 MySQL、Oracle、SQL Server 等,具有很好的可移植性。
二、Hibernate 的核心接口
Hibernate 的核心接口包括以下几个:

  1. SessionFactory:用于创建 Session 对象,一个 SessionFactory 对应一个数据库,通常情况下,一个应用程序只需要一个 SessionFactory。
  2. Session:用于执行持久化操作,如增删改查等。Session 是 Hibernate 的核心接口,所有的持久化操作都是通过 Session 完成的。
  3. Transaction:用于管理事务,确保数据库操作的原子性。Hibernate 的事务管理是通过 Transaction 接口实现的。
  4. Query:用于执行 HQL 查询。HQL(Hibernate Query Language)是 Hibernate 的查询语言,它类似于 SQL,但是操作的是对象而不是表。
  5. Criteria:用于执行条件查询。Criteria 接口提供了一种类型安全的查询方式,可以避免 SQL 注入等安全问题。
    三、Hibernate 的配置和使用
  6. 添加 Hibernate 依赖
    要在项目中使用 Hibernate,首先需要添加 Hibernate 的依赖。如果是 Maven 项目,可以在 pom.xml 文件中添加如下依赖:
    <dependencies>
     <!-- Hibernate 核心依赖 -->
     <dependency>
         <groupId>org.hibernate</groupId>
         <artifactId>hibernate-core</artifactId>
         <version>5.4.30.Final</version>
     </dependency>
     <!-- 数据库驱动依赖,以 MySQL 为例 -->
     <dependency>
         <groupId>mysql</groupId>
         <artifactId>mysql-connector-java</artifactId>
         <version>8.0.23</version>
     </dependency>
    </dependencies>
    
  7. 创建 Hibernate 配置文件
    Hibernate 的配置文件名为 hibernate.cfg.xml,通常放在项目的 resources 目录下。配置文件中主要配置数据库信息和 Hibernate 相关属性。一个简单的 hibernate.cfg.xml 文件如下:
    <!DOCTYPE hibernate-configuration PUBLIC
         "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
         "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
    <hibernate-configuration>
     <session-factory>
         <!-- 数据库驱动 -->
         <property name="hibernate.connection.driver_class">com.mysql.cj.jdbc.Driver</property>
         <!-- 数据库 URL -->
         <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test?serverTimezone=UTC</property>
         <!-- 数据库用户名 -->
         <property name="hibernate.connection.username">root</property>
         <!-- 数据库密码 -->
         <property name="hibernate.connection.password">root</property>
         <!-- Hibernate 方言 -->
         <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
         <!-- 显示 SQL -->
         <property name="hibernate.show_sql">true</property>
         <!-- 格式化 SQL -->
         <property name="hibernate.format_sql">true</property>
         <!-- 自动创建表 -->
         <property name="hibernate.hbm2ddl.auto">update</property>
     </session-factory>
    </hibernate-configuration>
    
  8. 创建实体类和映射文件
    实体类是 Java 中表示数据库表的类,映射文件用于描述实体类和数据库表之间的映射关系。例如,有一个名为 User 的表,表中有 id、name 和 age 三个字段,对应的实体类和映射文件如下:
    ```java
    // User.java
    public class User {
    private int id;
    private String name;
    private int age;
    // getter 和 setter 方法
    }
    // User.hbm.xml
    <!DOCTYPE hibernate-mapping PUBLIC
     "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
     "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
    

     <id name="id" column="id">
         <generator class="native"/>
     </id>
     <property name="name" column="name"/>
     <property name="age" column="age"/>
    

    </hib
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
Java 关系型数据库 数据库连接
JDBC:Java与数据库的“黄金搭档”,为何它如此重要?
JDBC:Java与数据库的“黄金搭档”,为何它如此重要?
50 8
|
4月前
|
Java 数据库连接 API
JDBC:Java数据库连接的“黑科技”大揭秘
JDBC:Java数据库连接的“黑科技”大揭秘
39 7
|
2月前
|
SQL Java 数据库
Springboot+spring-boot-starter-data-jdbc实现数据库的操作
本文介绍了如何使用Spring Boot的spring-boot-starter-data-jdbc依赖来操作数据库,包括添加依赖、配置数据库信息和编写基于JdbcTemplate的数据访问代码。
105 2
|
3月前
|
SQL 关系型数据库 数据库连接
php连接数据库之PDO,PDO的简单使用和预定义占位符的使用以及PDOStatement对象的使用,占位符的不同形式,bindValue和bindParam绑定预定义占位符参数的区别
本文介绍了PHP中PDO(PHP Data Objects)扩展的基本概念和使用方法。内容包括PDO类和PDOStatement类的介绍,PDO的简单使用,预定义占位符的使用方法,以及PDOStatement对象的使用。文章还讨论了绑定预定义占位符参数的不同形式,即bindValue和bindParam的区别。通过具体示例,展示了如何使用PDO进行数据库连接、数据查询、数据插入等操作。
php连接数据库之PDO,PDO的简单使用和预定义占位符的使用以及PDOStatement对象的使用,占位符的不同形式,bindValue和bindParam绑定预定义占位符参数的区别
|
2月前
|
SQL druid Java
JDBC和数据库连接池-两个工具类-JDBCUtilsByDruid和BasicDAO
JDBC和数据库连接池-两个工具类-JDBCUtilsByDruid和BasicDAO
35 0
|
4月前
|
SQL Java 数据库连接
JDBC之旅:从陌生到熟悉的Java数据库连接之路
JDBC之旅:从陌生到熟悉的Java数据库连接之路
32 9
|
3月前
|
Java 数据库连接 API
解锁高效开发秘籍:深入探究 Hibernate 如何优雅处理一对多与多对多关系,让数据映射再无烦恼!
【9月更文挑战第3天】Hibernate 是 Java 领域中最流行的 ORM 框架之一,广泛用于处理实体对象与数据库表之间的映射。尤其在处理复杂关系如一对多和多对多时,Hibernate 提供了丰富的 API 和配置选项。本文通过具体代码示例,展示如何使用 `@OneToMany`、`@JoinColumn`、`@ManyToMany` 和 `@JoinTable` 等注解优雅地实现这些关系,帮助开发者保持代码简洁的同时确保数据一致性。
54 4
|
4月前
|
SQL Java 数据库连接
Java开发者必知:JDBC连接数据库的“三大法宝”
Java开发者必知:JDBC连接数据库的“三大法宝”
37 7
|
3月前
|
SQL Java 数据库连接
Hibernate 批量操作来袭!掌握最佳实践,轻松应对数据洪流,开启高效开发新时代
【9月更文挑战第3天】在软件开发中,高效数据操作至关重要。作为流行的Java持久化框架,Hibernate提供了强大的数据库操作功能。本文探讨了Hibernate批量操作,包括批量插入、更新和删除的最佳实践,通过使用原生SQL和`Session`的`createNativeQuery()`方法,结合`addBatch()`及`executeBatch()`方法实现高效批量操作。合理设置批量大小、事务管理和性能测试是优化的关键。在实际开发中,应根据业务需求和性能要求选择合适的方法,以提升程序性能和可维护性。
218 3
|
4月前
|
SQL 安全 Java
JDBC:Java与数据库的“月老红线”,你真的了解它吗?
JDBC:Java与数据库的“月老红线”,你真的了解它吗?
23 1