精通Hibernate——Hibernate使用触发器需要注意的两点
2015-08-29 19:34
393 查看
数据库系统有时会利用触发器来完成某些业务规则。触发器在接收到特定的事件时被激发,执行事先定义好的一组数据库操作。能激发触发器运行的时间可以分为以下几种:
1.插入事件,insert
2.更新记录事件,update
3.删除记录事件,delete
Hibernate与数据库中的触发器协同工作时会造成两类问题:
1.触发器使Session的缓存中的数据与数据库不一致
在激发执行触发器之后在执行这个操作后,立即调用Session的flush和refresh方法,迫使Session的缓存与数据库同步。另一方面,如果执行完Session的save方法后不会再访问Customer对象,那么也没有必要迫使Session的缓存与数据库同步。
2.Session的update方法盲目的激发触发器
当配置文件配置如下:
当Session的update或saveOrUpdate方法更新一个Customer游离对象时,会先执行select语句,获得这个Customer对象子数据库中最新数据,然后比较Customer游离对象与数据库中的最新数据,然后比较Customer游离对象与数据库中的数据是否一致,只有在不一致的情况下才会执行update语句,这就避免了多余的update语句,以及盲目的激发相关的触发器。
1.插入事件,insert
2.更新记录事件,update
3.删除记录事件,delete
Hibernate与数据库中的触发器协同工作时会造成两类问题:
1.触发器使Session的缓存中的数据与数据库不一致
在激发执行触发器之后在执行这个操作后,立即调用Session的flush和refresh方法,迫使Session的缓存与数据库同步。另一方面,如果执行完Session的save方法后不会再访问Customer对象,那么也没有必要迫使Session的缓存与数据库同步。
2.Session的update方法盲目的激发触发器
当配置文件配置如下:
<class name="mypack.Customer" table="CUSTOMRS" select-before-update="true"></class>
当Session的update或saveOrUpdate方法更新一个Customer游离对象时,会先执行select语句,获得这个Customer对象子数据库中最新数据,然后比较Customer游离对象与数据库中的最新数据,然后比较Customer游离对象与数据库中的数据是否一致,只有在不一致的情况下才会执行update语句,这就避免了多余的update语句,以及盲目的激发相关的触发器。
相关文章推荐
- 继承TextView获取焦点实现跑马灯
- UIPageControll
- 对称加密和非对称加密介绍和区别
- 【C/C++】面向对象的基本概念
- 我的第一个C++程序
- UI20_KVO
- 主键和外键
- grep manual
- Ubuntu中安装zlib
- lintCode-给出若干闭合区间,合并所有重叠的部分。
- EM算法深入浅出
- hdu5410CRB and His Birthday 多重背包
- UIScrollView
- Android笔记一(Broadcast)
- UVa 10780 - Again Prime? No Time.(唯一分解)
- pat(B) 1012. 数字分类
- 红色警戒2修改器原理百科(三)
- mvc模式实现
- 【C/C++】this指针
- 一个比较low的防止用户持续刷入的办法