您的位置:首页 > 产品设计 > UI/UE

hibernate的查询死锁

2007-09-05 15:14 113 查看
  今天做了一个操作,先用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,开启之后,操作成功.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息