org.hibernate.HibernateException: delete is not valid without active transaction

 /**
  * 通过id来查找用户(删除用)
  */
 public Person findOneById(Long pid) {
  Transaction transaction = sessionFactory.getCurrentSession().beginTransaction();
  Person person = (Person)sessionFactory.getCurrentSession().get(Person.class, pid);
  transaction.commit();
  return person;
 }
 
 /**
  * 通过id 来删除该用户
  */
 public void deleteOneById(Long pid) {
  Transaction transaction = sessionFactory.getCurrentSession().beginTransaction();
  Person person = findOneById(pid);
  sessionFactory.getCurrentSession().delete(person);
  transaction.commit();
  sessionFactory.getCurrentSession().close();
 }

错误的原因

      在findOneById(Long pid)中间提交一次事务,然后在deleteOneById(Long pid)提交一个事务。

      把findOneById中的事务提交删除掉就OK!



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值