hibernate

本文详细介绍了Hibernate框架的基础用法、深入理解和高级特性,包括持久化对象的规则、映射文件的使用、关系映射、继承映射、批量处理、HQL查询、事务控制、缓存机制及事件机制等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、简介
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合
,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任
准备:
下载: http://sourceforge.net/projects/hibernate/files/hibernate4/4.3.9.Final/hibernate-release-4.3.9.Final.zip/download
安装:
New -web project/java project 添加 jar到WEB-INF/lib目录下
数据库 连接池:
Hibernate:


二、基础用法
1.Hibernate配置文件
Configuration对象
它提供了buildSessionFactory() 方法,该方法产生一个不可变的SessionFactory对象

配置hibernate的两种方式

使用hibrenate.properties 文件作为配置文件
实例化Configuration对象
Configuration configuration = new Configuration()
.addAnnotatedClass(UserEntity.class);//添加持久化类
configuration.configure();

使用hibernate.cfg.xml 文件作为配置文件
实例化Configuration对象
Configuration configuration = new Configuration().configure(); // 实例化配置文件

不使用配置文件创建
实例化Configuration对象
Configuration configuration = new Configuration().addAnnotatedClass(UserEntity.class).setProperty("数据库配置","值");

2.持久化对象
持久化对象应该遵守的规则:

提供一个无参构造器
提供一个标识属性(包装类作为标识属性的类型)
为每个成员属性添加setter和getter方法
使用非final的类
重写equals()和hashCode()方法

持久化对象的三个状态
瞬时:new 持久化对象时
持久化:session操作了持久化对象,未关闭session
脱管 :是指当session关闭后
更改持久化对象的状态方法

Hibernate session

session.save(Object obj);将obj对象变为持久化

session.persist(arg0);将obj对象变为持久化

session.saveOrUpdate(arg0, arg1)将obj对象变为持久化指定主键

session.persist(arg0, arg1)将obj对象变为持久化指定主键


3.Hibernate映射文件
将POJO变成PO类的三种方式

使用持久化注解

使用JPA2提供的XML配置描述文件

使用Hibernate传统的xml映射文件(.hbm.xml)

持久化注解
@Entity
注解修饰为POJO就是一个实体
@Tables
指定持久化类所映射的表name=”t_table”
映射主键
@GeneicGenerator
Name:
必须属性,设置主键生成器的名称。可以被@GeneratedValue的generator属性引用

Strategy:

必须属性,设置主键的生成策略

常用主键的生成策略
Increment
为long,short或者int 类型主键生成唯一标识

Identity
在db2,mysql,microsoft lserver,sybase,hypersonicesql等提供主键支持
Sequence
在db2,postgreSql,oracle,sap db,mckoi等提供主键支持
Hilo

Qeqhilo
uuid


三、深入
1.Hibernate的关系映射
1)一对多的映射(one-to-many)
2)一对一映射(One-to-One)
3)Many-to-Many映射(多对多映射关系)
2.继承映射
3.批量处理
HQL
Session.flush();//与数据库同步
Session.clearn();//清空一级缓存

JDBC
session.doWork();
4.HQL查询
HQL操作的是类和属性
在hibernate中没有insert ,只有update,delete,select


5.Criteria查询
纯面向对象的查询方式
6.SQL查询
HQL操作的是表和字段

7.数据过滤
8.事务控制
无非就是开始事务 提交事务 回

Session session=session.getCurrentSession();
Transaction transaction=session.getTransaction();
transaction.begin();
transaction.commit();
transaction.rollback();


9.缓存
一级缓存
是指对Session级别的缓存,当session关闭时,缓存就没有了
理解一级缓存的定义和产生
常用一级缓存常用操作方法:clear()/evcit()、flush()
clear()/evcit():清空缓存
flush():刷新缓存(判断缓存中对象属性是否跟数据库同步,如果不同步会发送更新语句)
显示调用
隐式调用:在事务提交之前会先flush缓存

二级缓存
二级缓存是对sessionfactory级别的缓存,可以是使用的三方组件有eacache,oscache; 官方推荐使用Eacache
使用:
添加lib\optional\ehcache下的jar包

添加二级缓存配置文件\project\etc\ehcache.xml

开启二级缓存
cache.use_second_level_cache true


产声二级缓存的提供者
cache.region.factory_class org.hibernate.cache.ehcache.EhCacheRegionFactory

指定要缓存的类
还有另外两种方式可以指定要缓存的类:
. hbm.xml
在<class>标签里,添加<cache usage="read-write" />
注解
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
ehcache.xml详解:
name:指定区域名,可以是类的全限定名和集合的名称
maxElementsInMemory :缓存在内存中的最大数目
maxElementsOnDisk:缓存在磁盘上的最大数目,若是0 表示无穷大
eternal :设置是否永远不过期,默认为false; 如果为true表示永不过期,将忽略timeToIdleSeconds和timeToLiveSeconds
overflowToDisk : 硬盘溢出数目
timeToIdleSeconds :对象处于空闲状态的最多秒数后销毁,如果为0,将无限期地处于空闲状态
timeToLiveSeconds :对象处于缓存状态的最多秒数后销毁,如果为0,将无限期地处于缓存状态,该属性必须大于等于timeToIdleSeconds
memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。有LRU(默认)、LFU、LFU

查询缓存
查询缓存依赖于二级缓存
开启查询缓存
<property name="cache.use_query_cache">true</property>
使用时:
query.setCacheable(true);


10.事件机制

四、集成
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值