Hibernate——操作持久化对象

session缓存

缓存:缓存是介于\color{#FF0000}{应用程序}\color{#FF0000}{数据库}之间的桥梁,他的作用是提高存取效率,降低应用程序直接读写数据库的频率。
缓存内的数据:是数据库中数据的复制,应用程序从缓存中读写数据,然后在特定的时候读取数据库数据。

session缓存:

session缓存:在内存当中,是一个对象的集合,把对象放到session缓存当中其实就是把对象引用放到集合当中。session缓存中的数据不会被来及回收机制回收掉,session缓存对象在堆区。
session缓存的执行过程:
查询方法:先从session中读取数据,如果session中没有要查询的数据再从数据库中查询。
save(),update()方法:先修改session中的内容,然后在特定时候修改数据库。

Session session = sessionfactory.openSession(); 
Transaction tx = session.beginTransaction()
User u1 = new User("Tom");
//这一步产生id值,id不再是默认值。
//是否执行insert语句要看主键生成策略。如果是identity,只有先插到数据库里面才知道id,会执行insert语句。如果是increment的话,通过select语句先要查询最大的id值,然后在commit之后进行插入。
//在这一步就可以打印出sql语句
session.save(u1);// 假设分配u的OID=3 
tx.commit(); // 提交事务 
u1 = null; 
User u2 = session.load(User.class, new Integer(3)); 
u1 = session.load(User.class, new Integer(2));
session.close(); // session关闭 ,session中不再保存数据
u2 = null; 
u1=null;
//u1,u2都会被回收掉

\color{#FF0000}{session清理缓存}

Session在某一时间点按照缓存中对象的属性变化来同步更 新数据库的这一过程被称为 Session 清理缓存。

缓存清理的时间点:

当调用 transaction.commit() 方法时,会先清理缓存, 再向数据库提交事务; 在这个方法当中调用了flush()。在他之后不能够进行回滚,一旦调用数据永远保存在数据库当中,无法撤销

当显式调用Session.flush()方法时,会清理缓存;在他之后可以进行数据库事物的回滚。回滚之后之前的操作撤销。

当调用 Session 的查询(不包括 load() 和 get() )方法 时,如果缓存中对象的属性有变化则清理缓存。防止读到脏数据。

session对象快照:

Session session = sessionfactory.openSession(); 
Transaction tx = session.beginTransaction();
User user = session.get(User.class, new Integer(1));
//跟快照之间产生差异
user.setName("Jack");
//因为清理缓存的时候发现不一致,所以更新了数据库
tx.commit();

session清理缓存的模式:

session清理缓存的模式

flushmode.MANUAL:用于程序执行时间很长的时候。commit清理内容过多。

session缓存的作用

hibernate对象的生命周期

\color{#FF0000}{四种状态}

(1)transient(临时状态):就是新对象刚刚new完之后,还没有被持久化,不在session的缓存中。
(2)persistent(持久化状态):已经被持久化,而且已经加到session缓存中。
(3)detached(游离状态):已经被持久化,但不在session缓存中:执行完close()之后
(4)removed(删除状态):session已经计划将其从数据库删除,并且不再处于session中。delete方法。

hibernate中的实体对象

实体对象的生命周期

注:
1.saveOrUpdate()方法。根据id自动判断,需要保存还是更新。id不是默认值就执行update()方法,是默认值就执行save()方法。
2.只有持久化状态的时候不能被回收。

hibernate操作持久化对象

1.save()方法:将对象变成持久化状态。会根据映射文件的配置方法产生OID。计划执行insert语句,但这个insert语句不一定是save方法产生的。

2.update()方法:把游离对象变成持久化对象。计划执行update语句。不管对象的属性有没有变化都会执行一个update语句(通过select-beforeupdate=true改设置<class>的变)。

3.delete()方法:检查传入的参数是否是持久化对象,如果是 持久化对象将其移出 Session 缓存;计划执行一个 delete,但是并不立即执行;当 Session 清理缓存时才执行 delete,比 如执行 Session.flush()。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容