首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

hibernate 学习札记二

2012-10-25 
hibernate 学习笔记二Hibernate中对象的状态---------------------------是否和session关联 数据库中是否

hibernate 学习笔记二
Hibernate中对象的状态
---------------------------

是否和session关联 数据库中是否有对应记录备注


自由状态NoNo

持久化状态YesYes     (具有脏检查功能)

游离状态NoYes

<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

热点排行