hibernate 的transaction和 session问题

devil13th 2013-02-01 11:29:52
用的SSH框架,事务切到service层, 在service取出一个用户列表,在action中循环此列表修改每个用户的角色id属性为角色名称后 , 数据库就变了呀 !!

在网上搜索了好久 说session关闭的时候会吧持久对象更新到数据库中,

但是自己做了一个例子



Transaction tx = session.beginTransaction();
Query query = session.createQuery("from Test01");
query.setFirstResult(begin);
query.setMaxResults(count);
List<Test01> l = (List<Test01>)query.list();
for(Test01 u : l){
u.setPwd("1");
}

tx.commit();
for(Test01 u : l){
System.out.println(u);
u.setPwd("22222");
session.update(u);
}
session.flush();
session.close();


修改后数据库中 pwd却是"1" 不是"22222" 为什么?


...全文
80 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
你第二个没有提交事务
dxqrr 2013-02-01
  • 打赏
  • 举报
回复
光flush没用,要commit

67,512

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧