今天遇到一个很奇怪的事情,用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修改数据的代码如下:
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()后,修改数据会出现增加数据,而不是修改数据的情况。