Hibernate + mysql 更新时死锁

mfkfjdcwy 2006-07-24 04:42:41
public class dao_setup {

public XdlSetup selectSetup()
{
XdlSetup setup ;
Session session;
String hql = "from XdlSetup setup";
Transaction tx;

session = HibernateSessionFactory.currentSession();
tx = session.beginTransaction();
setup = (XdlSetup)session.createQuery(hql).uniqueResult() ;
tx.commit() ;
return setup;
}
public void update(XdlSetup setup)
{
Session session = HibernateSessionFactory.currentSession() ;
Transaction tx = session.beginTransaction() ;
System.out.println("test");
session.saveOrUpdate(setup);
tx.commit() ;

}
public static void main(String[] args)
{
XdlSetup set = new dao_setup().selectSetup ();
System.out.println(set.getMasterEmail());
set.setMasterEmail("123456@");
new dao_setup().update( set);
}

}


Deadlock found when trying to get lock; Try restarting transaction message from server: "Lock wait timeout exceeded; try restarting transaction"
...全文
314 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
mfkfjdcwy 2006-07-26
  • 打赏
  • 举报
回复
解决了。
是我的字符不一致的原因
用过滤器就没有异常了
哈——
mfkfjdcwy 2006-07-25
  • 打赏
  • 举报
回复
加了,仍然不行
mfkfjdcwy 2006-07-25
  • 打赏
  • 举报
回复
我的HibernateSessionFactory怎么没有openSession()方法呀,我的HibernateSessionFactory只有currentSession(),closeSession()两个方法,我用的是Hibernate3.0
dreamover 2006-07-25
  • 打赏
  • 举报
回复

tx.commit();
后面加上
session.close()试试
benq998 2006-07-25
  • 打赏
  • 举报
回复
Session session = HibernateSessionFactory.currentSession() ;
改称
Session session = HibernateSessionFactory.openSession() ;

试试看。以前我用过一次HibernateSessionFactory.currentSession() ;结果线程阻塞。
老土豆T 2006-07-25
  • 打赏
  • 举报
回复
如果是并发的,更新的又是同一条数据,当然会锁了.
mfkfjdcwy 2006-07-24
  • 打赏
  • 举报
回复
是不是字段太多的原因呀,我的这个对象setup的字段有80多个,而其它的少字段表的相同的操作都可以,不过有点慢。

现在还没有解决这个原因
太急人了!!!!!
mfkfjdcwy 2006-07-24
  • 打赏
  • 举报
回复
是一样的呀,还是那个异常。
dreamover 2006-07-24
  • 打赏
  • 举报
回复
dao_setup dao = new new dao_setup();
XdlSetup set = dao.selectSetup ();
System.out.println(set.getMasterEmail());
set.setMasterEmail("123456@");
dao.update(set);

67,513

社区成员

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

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