Skip to content

java hibernate重温之数据库隔离级别与持久化对象

今天无意又看到了hibernate的数据库隔离级别与持久化对象。
感觉还是忘记了些,所以记录下。
数据库隔离级别
1、Read Uncommited(未提交读):没有提交就可以读取到数据(发出了Insert,但没有commit就可以读取到。)很少用

2、Read Commited(提交读):只有提交后才可以读,常用

3、Repeatable Read(可重复读):mysql默认级别, 必需提交才能见到,读取数据时数据被锁住

4、Serialiazble(序列化读):最高隔离级别,串型的,你操作完了,我才可以操作,并发性特别不好

脏读:没有提交就可以读取到数据称为脏读

不可重复读:再重复读一次,数据与你上的不一样。称不可重复读

幻读:在查询某一条件的数据,开始查询的后,别人又加入或删除些数据,再读取时与原来的数据不一样了

持久化对象的状态:
1、瞬时对象(Transient Object):使用new操作符初始化的对象不是立刻就持久的。它们的状态是瞬时的,也就是说它们没有任何跟数据库表相关联的行为,只要应用不再引用这些对象(不再被任何其它对象所引用),它们的状态将会丢失,并由垃圾回收机制回收

2、持久化对象(Persistent Object):持久实例是任何具有数据库标识的实例,它由持久化管理器Session统一管理,持久实例是在事务中进行操作的—-它们的状态在事务结束时同数据库进行同步。当事务提交时,通过执行SQL的INSERT、UPDATE和DELETE语句把内存中的状态同步到数据库中

3、离线对象(Detached Object):Session关闭之后,持久化对象就变为离线对象。离线表示这个对象不能再与数据库保持同步,不再受hibernate管理

Transient对象:随时可能被垃圾回收器回收(在数据库中没有于之对应的记录,是new初始化),没有纳入session的管理,而执行save()方法后,就变为Persistent对象(持久性对象)

Persistent对象:在数据库中有存在的对应的记录,纳入session管理。在清理缓存(脏数据检查)的时候,会和数据库同步

Detached对象:也可能被垃圾回收器回收掉(数据库中存在对应的记录,只是没有任何对象引用它是指session引用),没有纳入session的管理

2 Comments

    • ww1516123 ww1516123

      都差不多~ 其实.net我觉得做的东西更实际亲民点。

发表评论

电子邮件地址不会被公开。 必填项已用*标注