关于hibernate-dynamic-update的注意事项

此属性位于hbm文件class标签-->

<hibernate-mapping>
    <class name="com.example.A" table="A" dynamic-update="true">

添加后可以动态生成更新数据的sql语句,所谓动态,就是如果我们A表有5个字段分别是abcde,我们只对bc进行了修改,那么hibernate生成的update语句就会为

update A set b=x,c=y where a =xx;

而不是

<pre name="code" class="sql">update A set b=x,c=y,d=z,e=xy where a=xx;

通过此属性,我们可以实现对数据库的某些字段的更新.

但,这个属性有一个大大的坑,就是如果我们进行了这样的操作-->

A a = (A)getHibernateTemplate().get(A.class, id);//id可能是其他的类型,需要传入对应的
String newb = "newb";
String newc = null;
a.setB(newb);
a.setC(newc);

我们认为hibernate会因为c=null而忽略对C的更新,那么恭喜你,掉坑里了.实际上hibernate生成的sql-->

update A set b=newb,c=null where a=xx;

好了,这个坑就是这样,各位警戒吧.

时间: 2024-10-12 03:10:34

关于hibernate-dynamic-update的注意事项的相关文章

hibernate的update() 更新延迟或者无法更新,导致同个service调用存储过程执行方法不精确

hibernate的update()方法无法更新,不报错 原因是hibernate的update方法操作的是缓存,可以flush下先. 设置缓存为false理论上也可. 在一个serivce方法里,执行一个update操作,更新数据的状态,再调用存储过程对数据统计, 却一直统计不精确,因为每次都是存储过程先执行,后service方法执行完毕,才执行update操作, 针对此种情况,可以在执行update操作后,执行flush操作,让更新立即实现

Hibernate 中update hql语句

今天在MySQL中用hibernate测试update语句发现以下问题: update语句竟然不去作用: 表机构如下: create table student(sid int primary key , sname varchar(45) not null, ssex char(2) not null,sdept varchar(10) not null,sage int ,saddress varchar(45) ); update语句如下: String[] params = new St

hibernate中update与saveOrUpdate的区别

[转]hibernate中update与saveOrUpdate的区别 分类: Hibernate总结 2009-11-17 00:04 2121人阅读 评论(0) 收藏 举报 hibernatesession数据库javadaoapplication 先来点概念: 在Hibernate中,最核心的概念就是对PO的状态管理.一个PO有三种状态: 1.未被持久化的VO 此时就是一个内存对象VO,由JVM管理生命周期 2.已被持久化的PO,并且在Session生命周期内 此时映射数据库数据,由数据库

hibernate的update、merge和saveOrUpdate的区别(转)

1.首先 saveOrUpdate返回void 也就是什么都不返回 而merge会返回一个对象 2.其次 saveOrUpdate的做法是:自动判断该对象是否曾经持久化过,如果曾持久化过则使用update操作 否则save操作,merge 在执行session.merge(a)代码后,a对象仍然不是持久化状态,a对象仍然不会被关联到Session上 而update会持久化对象 1.pojo对象中有属性为null时,使用merge不更新数据库,使用saveOrUpdate更新数据库. 使用save

Hibernate 的update语句性能详解

Hibernate 中如果直接使用 Session.update(Object o); 会把这个表中的所有字段更新一遍. 比如: view plaincopy to clipboardprint? public class TeacherTest { @Test public void update(){ Session session = HibernateUitl.getSessionFactory().getCurrentSession(); session.beginTransactio

hibernate save,update,saveorupdate方法有什么区别

save肯定是添加的时候用,update修改时候用,saveorupdate是添加或修改,如果真是这样save和update的存在就没意义了,我们直接saveorupdate就行了. save在添加用的时候 不会出现索引机制(即遍历目录 效率最高)update在修改时候要遍历 不存在则会异常saveorupdate是优先遍历 如果不存在则创建(效率最低)merge和saveOrUpdate方法区别在于:merge方法是把我们提供的对象转变为托管状态的对象:而saveOrUpdate则是把我们提供

Hibernate 批量update数据时,怎么样做可以回滚,

1.serviceManagerDaoImpl代码里对异常不进行try,catch抛出, 2.或者抛出throw new RuntimeException()异常

Hibernate三种状态,缓存,以及update更新问题

一. Hibernate中对象的三种状态 1. 瞬时状态(transient) 当我们通过Java的new关键字来生成一个实体对象时,这时这个实体对象就处于自由状态,此时该对象只是通过JVM获得了一块内存空间,还并没有通过Session对象的save()方法保存进数据库,因此也就还没有纳入Hibernate的缓存管理中,也就是说该对象现在还自由的游荡于Hibernate缓存管理之外.所以我们可以看出自由对象最大的特点就是,在数据库中不存在一条与它对应的记录. 瞬时状态特点: I: 不和 Sess

Hibernate三种装套,缓存,以及update更新问题

一. Hibernate中对象的三种状态 1. 瞬时状态(transient) 当我们通过Java的new关键字来生成一个实体对象时,这时这个实体对象就处于自由状态,此时该对象只是通过JVM获得了一块内存空间,还并没有通过Session对象的save()方法保存进数据库,因此也就还没有纳入Hibernate的缓存管理中,也就是说该对象现在还自由的游荡于Hibernate缓存管理之外.所以我们可以看出自由对象最大的特点就是,在数据库中不存在一条与它对应的记录. 瞬时状态特点: I: 不和 Sess

Hibernate save, saveOrUpdate, persist, merge, update 区别

Hibernate save, saveOrUpdate, persist, merge, update 区别 - 小黑客 - 博客园https://www.cnblogs.com/xiaoheike/p/5374613.html Hibernate save()与persist()区别 - 山楂树男孩的博客专栏 - CSDN博客https://blog.csdn.net/u010739551/article/details/47253881 hibernate中save,update,save