public void test() {

Session session=sessionFactory.getCurrentSession();


//删除方法1
Teacher teacher=new Teacher();
teacher.setId(6);

//数据库中存在id为6的记录,但name字段是"teacher"这里却删除成功
teacher.setName("不影响");
session=sessionFactory.getCurrentSession();
session.beginTransaction();
session.delete(teacher);
session.getTransaction().commit();

//删除方法2
session=sessionFactory.getCurrentSession();
session.beginTransaction();
teacher=(Teacher)session.load(Teacher.class, 7);
session.delete(teacher);
session.getTransaction().commit();

}

总结:

  session的delete方法删除的时候是通过主键进行删除的,所以在方法1中即使设置了不对应的其它字段也是可以正常删除数据的,如果数据库没有存在对应的主键值,会出现下面的异常 ---Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1

 

最后记住:

  1) session的delete方法是通过主键进行删除的,主键不存在则异常

  2) 持久状态对象被delete后变成瞬时状态对象

相关文章:

  • 2021-08-26
  • 2021-10-30
  • 2021-08-08
  • 2021-11-18
  • 2021-10-26
  • 2022-01-18
  • 2021-09-16
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-11-24
  • 2022-01-02
  • 2021-07-05
  • 2021-10-14
  • 2022-01-07
  • 2022-12-23
相关资源
相似解决方案