今天做了一个操作,先用hibernate进行查询,在查询集合list的循环中又执行 按上一个查询结果做条件的一个更新操作,我先是用Query加载sql语句,再用Query.executeUpdate去执行,结果抛除异常并且进入死锁状态,查了很多资料,有点收获.
Hibernate在 update持久对象的时候,产生的sql语句是把所有的属性统统set一遍,这样会造成update操作效率很低。Hibernate默认情况下总是在初始化的时候静态生成sql语句,因此不能动态update。但是Hibernate也可以配置为动态产生update和insert语句。
<class name="ClassName" table="tableName" dynamic-update="true|false" > dynamic-insert="true|false" />
当设为true的时候,Hibernate在运行期动态产生sql语句,对于insert来说,只插入那些不是null的属性,这样就可以支持数据库字段的default属性;对于update来说,只更新那些修改过的属性。
加入上边这段代码,然后我不在执行循环中的查询操作直接用vo对象去set这个要修改的值,再session.update(vo);
没有报错,但是数据库中没有值,找了半天发现没有启用Transaction,开启之后,操作成功.
本文介绍了一种在使用Hibernate框架时遇到的更新操作死锁问题及其解决方案。通过配置dynamic-update属性为true,使得Hibernate能够动态生成SQL语句,仅更新已修改的属性,从而提高更新操作的效率。
36

被折叠的 条评论
为什么被折叠?



