今天在使用struts2+HIbernate时进行插入操作时,SQL语句已经打印,但是数据库中没值,很是纳闷,经过仔细查找并查阅相关资料,发现Hibernate在生成DAO时并没有为我们提交事务,实例代码:
public void save(Users transientInstance) {
log.debug("saving Users instance");
try {
getSession().save(transientInstance);
log.debug("save successful");
} catch (RuntimeException re) {
log.error("save failed", re);
throw re;
}
}
这是Hibernate自动生成的代码,因为没有提交事务,导致虽然程序不报错,但数据就是不能加入数据库中,因此,应该这样写:
public void save(Users transientInstance) {
log.debug("saving Users instance");
/********************获取sessionFactory对象**********/
Transaction tx=getSession().beginTransaction();
try {
getSession().save(transientInstance);
log.debug("save successful");
/***************提交事务*****************/
tx.commit();
} catch (RuntimeException re) {
log.error("save failed", re);
throw re;
}finally{
/****************************关闭SessionFactory***************************/
HibernateSessionFactory.closeSession();
}
}
这样写就能保证事务提交了,数据库中便可添加数据!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/96898.html