hibernate的查询死锁

未分类 发表评论

  今天做了一个操作,先用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,开启之后,操作成功.

发表评论

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

昵称 *