用hibernate,修改数据后,在数据库中查看,已经修改成功了。前台页面显示的内容却新旧数据交替出现,刷新一下页面可能是修改后的数据,再刷新一下,可能又是修改前的数据了。要过一段时间才能稳定显示出来。该怎么解决这样的问题呀?
我的hibernate修改数据的代码如下:
Session session = dao.getSession();
Transaction tx = null;
tx = session.beginTransaction();
try{
AppTongzgg appTongzgg1 = dao.findById(appTongzgg.getId());
appTongzgg1.setBiaot(appTongzgg.getBiaot());
appTongzgg1.setZhengw(appTongzgg.getZhengw());
tx = session.beginTransaction();
session.save(appTongzgg1);
tx.commit();
return true;
}catch(Exception e){
e.printStackTrace(System.out);
return false;
}finally{
session.flush();
session.clear();
session.close();
}
[b]问题补充:[/b]
原来查的代码是
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;
}
}
刚才改成
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();
经过测试,暂时没出现那样的情况了。
给你点建议 getSession()最好每次都返回一个新的session不要公用 session本身比较轻量 每次创建一个不费什么时间 如果公用就得小心点用了 可是有缓存的 像你的这段查询代码 你在最后应该用完就关闭session就不会有问题了 你不每次都新建立一个session也行 但是得注意线程安全问题 得用ThreadLocal保存session看看下面这两个链接
http://louisyoo.blog.ccidnet.com/blog-htm-do-showone-uid-41414-type-blog-itemid-117519.html
http://selvemen.iteye.com/blog/457225
数据库里查看没有问题 就证明应该是你存的没有问题 关键是看你查询的代码啊。
还有你为什么tx = session.beginTransaction(); 要写两遍那
session是有缓存的 你的getSession()方法里是不是 不是每次都新建立一个session啊 这样如果不清空session的缓存话会有问题的