用 hibernate 修改数据的奇怪问题。
2009-12-02 23:36
274 查看
今天遇到一个很奇怪的事情,用hibernate
修改数据后,在数据库中查看,已经修改成功了。前台页面显示的内容却新旧数据交替出现,刷新一下页面可能是修改后的数据,再刷新一下,可能又是修改前的数据了。要过一段时间才能稳定显示出来。对hibernate刚上手,不熟悉,搞的我头都大了也没搞定。后来试着改代码,最终找到的问题所在。
我的hibernate修改数据的代码如下:
Session session = dao.getSession();
Transaction tx = null;
try{
AppTongzgg appTongzgg1 =
dao.findById(appTongzgg.getId());
appTongzgg1.setBiaot(appTongzgg.getBiaot());
appTongzgg1.setZhengw(appTongzgg.getZhengw());
tx =
session.beginTransaction();
//session.save(appTongzgg1);
session.merge(appTongzgg1);
tx.commit();
return true;
}catch(Exception e){
e.printStackTrace(System.out);
return false;
}finally{
session.clear();
session.close();
}
查信息的代码是
public AppTongzgg findById(java.lang.Integer id) {
log.debug("getting
AppTongzgg instance with id: " + id);
Session session = getSession();
try {
AppTongzgg instance = (AppTongzgg) session.get(
"com.thtf.oa.tongzgg.bean.AppTongzgg", id);
return instance;
} catch
(RuntimeException re) {
log.error("get failed", re);
throw re;
}finally{
session.clear();
}
}
在查信息的方法中最后加上session.clear(); 问题就能解决。
还有就是,修改数据时不用session.save(),而用session.merge().不然在查数据中加上session.clear()后,修改数据会出现增加数据,而不是修改数据的情况。
修改数据后,在数据库中查看,已经修改成功了。前台页面显示的内容却新旧数据交替出现,刷新一下页面可能是修改后的数据,再刷新一下,可能又是修改前的数据了。要过一段时间才能稳定显示出来。对hibernate刚上手,不熟悉,搞的我头都大了也没搞定。后来试着改代码,最终找到的问题所在。
我的hibernate修改数据的代码如下:
Session session = dao.getSession();
Transaction tx = null;
try{
AppTongzgg appTongzgg1 =
dao.findById(appTongzgg.getId());
appTongzgg1.setBiaot(appTongzgg.getBiaot());
appTongzgg1.setZhengw(appTongzgg.getZhengw());
tx =
session.beginTransaction();
//session.save(appTongzgg1);
session.merge(appTongzgg1);
tx.commit();
return true;
}catch(Exception e){
e.printStackTrace(System.out);
return false;
}finally{
session.clear();
session.close();
}
查信息的代码是
public AppTongzgg findById(java.lang.Integer id) {
log.debug("getting
AppTongzgg instance with id: " + id);
Session session = getSession();
try {
AppTongzgg instance = (AppTongzgg) session.get(
"com.thtf.oa.tongzgg.bean.AppTongzgg", id);
return instance;
} catch
(RuntimeException re) {
log.error("get failed", re);
throw re;
}finally{
session.clear();
}
}
在查信息的方法中最后加上session.clear(); 问题就能解决。
还有就是,修改数据时不用session.save(),而用session.merge().不然在查数据中加上session.clear()后,修改数据会出现增加数据,而不是修改数据的情况。
相关文章推荐
- 遇见了奇怪bug,前端用的AngularJs,后台是SpringMVC,持久用的hibernate,跟后台断点时查询数据库返回一条数据,否则返回两条,以下是问题详述
- SSH框架之Hibernate一对多关系数据绑值修改删除出现问题
- hibernate 一对一、多对一 双向关联的问题——只能在多的一方添加、修改数据,不能在多的一方修改添加
- Hibernate3不使用事务无法保存或修改数据问题
- hibernate在分层架构中修改数据(update)时遇到的问题!!
- hibernate保存数据后在修改的时候结果是老数据的问题
- 遇到奇怪的问题,帮助威猛答案,表单提交的文件提交的无限数据问题
- hibernate学习过程问题(1)--通过代码保存数据时,数据库始终只有一条数据
- 工作中遇到的问题:百万条数据的查询、删除、修改效率提高的一些思考,解决方案(一)
- 如何解决使用addBatch()和executeBatch()无法批量增加删除修改数据库数据等问题
- jdbc与hibernate结合修改子表数据(jdbc删除、hibernate更新/添加)
- Fiddler的实践心得(二):修改Response数据时要注意超时的问题
- hibernate刷新数据时的缓存问题
- 关于修改表字段数据类型的问题(ORA-22859: 无效的列修改 )
- 修改编辑文件夹名称, put数据出现的问题
- hive的数据修改更新问题解决
- hibernate做数据同步时的问题
- hibernate刷新数据时的缓存问题
- C++中转义序列与数据赋值的奇怪问题
- 小学生之Hibernate插入数据修改数据使用数据库默认值的实现