博客
关于我
Hibernate学习(1)- 初识
阅读量:796 次
发布时间:2023-03-21

本文共 3261 字,大约阅读时间需要 10 分钟。

Hibernate入门与实践指南

一、Hibernate基础概念

持久化是Hibernate的核心概念,主要解决了关系型数据库与对象的不匹配问题。简单来说,持久化就是将对象的状态持久化到数据库中,保证数据不会丢失。

1. 持久化的理解

  • 狭义概念:数据存储在物理介质中,永远不会丢失。
  • 广义概念:Hibernate中,CRUD操作都被称为持久化。

2. 加载

在Hibernate中,数据是通过Session从数据库加载到内存中的。Session可以看作是对数据库连接的包装,负责事务管理和缓存。

3. ORM(Object Relation Mapping)

Hibernate是一种ORM框架,通过将POJO与数据库表映射起来,解决了传统 JDBC 在数据库操作中存在的阻抗不匹配问题。其优势主要体现在:

  • 无侵入性:不需要继承或实现Hibernate提供的类或接口。
  • 高效性:减少了大量冗余的数据库操作代码,提高了开发效率。

二、Hibernate的第一堂课

1. 环境搭建

1.1 资源包结构

Hibernate项目通常包含以下几个目录:

  • documentation:相关文档。
  • lib:Hibernate及相关jar包。
  • project:项目源码、模板文件等。

1.2 必要jar包

  • Hibernate核心jar包。
  • 数据库驱动jar包(如MySQL驱动)。
  • 其他依赖jar包。

1.3 配置文件

  • hibernate.cfg.xml:主要配置数据源、连接参数、Hibernate方言等。
  • User.hbm.xml:映射User实体与数据库表。

1.4 数据库创建

创建一个简单的用户表:

CREATE TABLE `user` (  `id` bigint(20) NOT NULL AUTO_INCREMENT,  `name` varchar(255) DEFAULT NULL,  `pwd` varchar(255) DEFAULT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;

1.5 实体类

package com.demo.pojo;public class User {    private Long id;    private String name;    private String pwd;    // setter和getter方法    // ...}

1.6 映射文件

2. 测试与运行

2.1 测试类

package com.demo.test;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.Transaction;import org.hibernate.boot.MetadataSources;import org.hibernate.boot.registry.StandardServiceRegistry;import org.hibernate.boot.registry.StandardServiceRegistryBuilder;import org.junit.jupiter.api.Test;import com.demo.pojo.User;public class QueryTest {    @Test    public void connectTest() {        // 配置ServiceRegistry并创建SessionFactory        StandardServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().configure().build();        SessionFactory sessionFactory = new MetadataSources(serviceRegistry).buildMetadata().buildSessionFactory();        Session session = sessionFactory.openSession();        // 开始事务        Transaction transaction = session.beginTransaction();        // 保存用户        User user = new User();        user.setName("张三");        user.setPwd("123456");        session.save(user);        // 提交事务        transaction.commit();        // 关闭Session        session.close();    }    @Test    public void queryTest() {        // 获取具体的用户        User user = session.get(User.class, 8L);        System.out.println(user);        // 提交事务        transaction.commit();        // 关闭Session        session.close();    }    @Test    public void saveTest() {        // 同connectTest的逻辑,省略重复代码    }}

三、Hibernate常用配置解读

  • hibernate.cfg.xml
    com.mysql.jdbc.Driver
    jdbc:mysql://localhost:3306/hibernate_test
    json
    123456
    org.hibernate.dialect.MySQL5Dialect
    true
    true
    update

四、Hibernate的核心概念解析

  • Session:与数据库连接相关的工厂,负责事务管理和缓存。
  • Transaction:事务对象,用于管理数据库事务。
  • Query:用于执行数据库查询。

五、注意事项

  • hbm2ddl.auto配置需谨慎处理,避免频繁重建数据库表。
  • 事务管理:确保事务正确提交或回滚,防止数据不一致。
  • 缓存管理:合理配置缓存,避免高并发下的性能问题。

通过以上配置和实践,熟悉了Hibernate的基本使用方法和配置方式,可以为后续的开发工作打下坚实基础。

转载地址:http://xyqfk.baihongyu.com/

你可能感兴趣的文章
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
mutiplemap 总结
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>
mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
查看>>
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>