hibernate的查询死锁
2007-09-05 15:14
113 查看
今天做了一个操作,先用hibernate进行查询,在查询集合list的循环中又执行 按上一个查询结果做条件的一个更新操作,我先是用Query加载sql语句,再用Query.executeUpdate去执行,结果抛除异常并且进入死锁状态,查了很多资料,有点收获.
Hibernate在 update持久对象的时候,产生的sql语句是把所有的属性统统set一遍,这样会造成update操作效率很低。Hibernate默认情况下总是在初始化的时候静态生成sql语句,因此不能动态update。但是Hibernate也可以配置为动态产生update和insert语句。
当设为true的时候,Hibernate在运行期动态产生sql语句,对于insert来说,只插入那些不是null的属性,这样就可以支持数据库字段的default属性;对于update来说,只更新那些修改过的属性。
加入上边这段代码,然后我不在执行循环中的查询操作直接用vo对象去set这个要修改的值,再session.update(vo);
没有报错,但是数据库中没有值,找了半天发现没有启用Transaction,开启之后,操作成功.
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的查询死锁
- Hibernate学习31 -- Hibernate查询语言(HQL)5 -- 直接使用sql进行查询
- Hibernate-----SQL查询 addScalar()或addEntity()
- 显示Hibernate查询时候的占位符
- Hibernate工具类和插入查询数据例子
- hibernate使用createQuery(hql)语句仅查询部分字段,应如何获得数据
- Hibernate中的createQuery查询一条数据、多条数据、分页查询数据
- Hibernate的命名查询(NamedQuery)
- sql查询死锁
- 转:hibernate查询方法
- Hibernate查询方式l比较
- Hibernate高级查询方法
- Hibernate学习(二)---HQL查询语言
- hibernate的hql查询语句总结
- Hibernate createCriteria查询详解
- Hibernate hql 查询指定字段并获取结果集
- Hibernate 通过批量ID进行查询所对应的对象集合
- Hibernate 查询说明
- Hibernate学习——(十二)Hibernate缓存机制(一级、二级、查询)
- 是否增加group by对Hibernate查询结果的影响