Hibernate中对象的状态
---------------------------
是否和session关联 数据库中是否有对应记录 备注
自由状态 No No
持久化状态 Yes Yes (具有脏检查功能)
游离状态 No Yes
<dynamic-update>
如果设为true,不使用缓存内的SQL语句,动态生成Update语句(大量进行更新操作并且只修改局部时设为true)
----------------------------------------------------------------------------------------------------------------------------------
获取对象
---------------------------
get()/load()区别
1、当表中没有对应记录时,get() 返回null,而load()抛出异常
2、get()直接到数据库中去查询记录,而load()先到缓里查,如果缓存里没有再到数据库中去查
3、get()不使用代理类,而load()使用代理类[代理类(ProxyClass)一般在延迟加载时使用
HQL
Criteria
SQL
----------------------------------------------------------------------------------------------------------------------------------
级联
---------------------------
级联类型:
none:默认值,不级联;
save-update:级联保存和更新;
delete:级联删除,不依赖数据库的级联设置,通过多条delete语句实现级联删除;
delete-orphan:在级联删除的基础上做到解除关系即删除;
all:save-update和delete效果的合成;
all-delete-orphan:all和delete-orphan效果的合成;
----------------------------------------------------------------------------------------------------------------------------------
批处理操作
---------------------------
session.flush()
将session缓存中信息,写入JDBC连接
session.clear()
将缓存清空
----------------------------------------------------------------------------------------------------------------------------------
事务
---------------------------
JTA:JDBC 事务构架
采用两阶段提交协议解决分布式事务,必须要服务器支持
Flush Mode
通过FlushMode关键字改变清理缓存发生的时刻:
查询 tran.commit() session.flush()
AUTO 发生 发生 发生
COMMIT 不发生 发生 发生
NEVER 不发生 不发生 发生
并发访问问题:
1、脏读: 一个事务读取另一个事务中的数据
2、不可重复读:一个事务两次读取相同的数据内容,结果不一致
3、虚读: 一个事务两次读取相同的统计数据,结果不一致
4、第一类丢失更新:一个事务将另一个事务已提交的数据回滚掉
5、第二类丢失更新:一个事务修改掉另一个并发事务修改提交的内容
通过设置隔离级别解决并发问题:
一丢 脏读 不可重复读 二丢 虚读
1: 解决 没解决 没解决 没解决 没解决
2: 解决 解决 没解决 没解决 没解决
4: 解决 解决 解决 解决 没解决
8: 解决 解决 解决 解决 解决
Oracle只支持Read commited Serializable
悲观锁
LockMode
None:先到缓存中取数据中,缓存中没有再到数据库中取数据
READ:同时到缓存和数据库中取数据,并进行比较
UPGRADE:检索到对象后便对其加锁
UPGRADE_NOWAIT:如果要检索对象被加锁,则不等待,直接报错
WRITE:默认状态
乐观锁
在表、POJO类及映射文件中加version
---------------------------
是否和session关联 数据库中是否有对应记录 备注
自由状态 No No
持久化状态 Yes Yes (具有脏检查功能)
游离状态 No Yes
<dynamic-update>
如果设为true,不使用缓存内的SQL语句,动态生成Update语句(大量进行更新操作并且只修改局部时设为true)
----------------------------------------------------------------------------------------------------------------------------------
获取对象
---------------------------
get()/load()区别
1、当表中没有对应记录时,get() 返回null,而load()抛出异常
2、get()直接到数据库中去查询记录,而load()先到缓里查,如果缓存里没有再到数据库中去查
3、get()不使用代理类,而load()使用代理类[代理类(ProxyClass)一般在延迟加载时使用
HQL
Criteria
SQL
----------------------------------------------------------------------------------------------------------------------------------
级联
---------------------------
级联类型:
none:默认值,不级联;
save-update:级联保存和更新;
delete:级联删除,不依赖数据库的级联设置,通过多条delete语句实现级联删除;
delete-orphan:在级联删除的基础上做到解除关系即删除;
all:save-update和delete效果的合成;
all-delete-orphan:all和delete-orphan效果的合成;
----------------------------------------------------------------------------------------------------------------------------------
批处理操作
---------------------------
session.flush()
将session缓存中信息,写入JDBC连接
session.clear()
将缓存清空
----------------------------------------------------------------------------------------------------------------------------------
事务
---------------------------
JTA:JDBC 事务构架
采用两阶段提交协议解决分布式事务,必须要服务器支持
Flush Mode
通过FlushMode关键字改变清理缓存发生的时刻:
查询 tran.commit() session.flush()
AUTO 发生 发生 发生
COMMIT 不发生 发生 发生
NEVER 不发生 不发生 发生
并发访问问题:
1、脏读: 一个事务读取另一个事务中的数据
2、不可重复读:一个事务两次读取相同的数据内容,结果不一致
3、虚读: 一个事务两次读取相同的统计数据,结果不一致
4、第一类丢失更新:一个事务将另一个事务已提交的数据回滚掉
5、第二类丢失更新:一个事务修改掉另一个并发事务修改提交的内容
通过设置隔离级别解决并发问题:
一丢 脏读 不可重复读 二丢 虚读
1: 解决 没解决 没解决 没解决 没解决
2: 解决 解决 没解决 没解决 没解决
4: 解决 解决 解决 解决 没解决
8: 解决 解决 解决 解决 解决
Oracle只支持Read commited Serializable
悲观锁
LockMode
None:先到缓存中取数据中,缓存中没有再到数据库中取数据
READ:同时到缓存和数据库中取数据,并进行比较
UPGRADE:检索到对象后便对其加锁
UPGRADE_NOWAIT:如果要检索对象被加锁,则不等待,直接报错
WRITE:默认状态
乐观锁
在表、POJO类及映射文件中加version