Hibernate delete方法:删除对象

delete() 方法的作用是删除与传入的持久化类对象对应的数据库中的记录。传入的持久化类对象可以是持久化状态的,也可以是游离状态的,但不可以是临时状态的。如果是持久化状态的。则在销毁 Session 清理缓存时执行 delete 语句;如果是游离状态的,首先将游离状态的对象转变为持久化状态,然后在销毁 Session 清理缓存时执行 delete 语句。

语法:

delete(Object object)

参数说明:

  • object:实体类的对象,用于指定删除哪个持久化对象中的数据。

示例1

应用 delete 方法删除对象,这里为删除指定的一条用户信息,关键代码如下:

Session session = sessionFactory.openSession();
Transaction tx = null;
try{
  tx = session.beginTransaction();  //开启事务//通过HQL查询创建一个处于持久化状态的对象
  UserForm uf = (UserForm)session.createQuery("from UserForm where username='sk'").
    setMaxResults(1).uniqueResult();
  session.delete(uf);  //删除指定的用户信息
  tx.commit();//提交事务
}catch(Exception e){
  if(tx!=null){
    tx.rollback();  //回滚事务
  }
}

示例2

批量删除用户名为 sk 的数据,关键代码如下:

Session session = sessionFactory.openSession();
Transaction tx = null;
try{
  tx = session.beginTransaction();  //开始事务
  List list = session.createQuery("from UserForm where username='sk'").list();
  Iterator it = list.iterator();
  while(it.hasNext()){
    UserForm uf = (UserForm)it.next();  //获取一个对象
    session.delete(uf);  //删除指定对象
  }
  tx.commit();  //提交事务
}catch(Exception e){
  if(tx!=null){
    tx.rollback();  //回滚事务
  }
}

典型应用

Session 中定义了各种操作数据库的方法,delete() 方法用于删除数据。当实现删除数据时,首先实现查询要删除的数据,然后进行删除操作。

本示例使用 Hibernate 框架查询数据,在使用该框架前要创建与用户表 tb_users 对应的 JavaBean 对象 Users,与其映射文件 Users.hbm.xml,可参考下载的源码。创建 Delete 类,在该类中定义删除数据方法,关键代码如下:

public static void main(String[] args){
  Session session = null;  //声明Session对象
  try{
    session = HibernateUtil.getSession();  //获取Session
    session.beginTransaction();  //开启事务//查询要删除指定的用户信息
    Users uf = (Users)session.createQuery("from Users where uName='tsoft'").
      setMaxResults(1).uniqueResult();
    session.delete(uf);  //执行删除数据方法
    System.out.println("成功删除了名称为tsoft的用户");
    session.getTransaction().commit();  //提交事务
  }catch(Exception e){
    e.printStackTrace();
    session.getTransaction().rollback();  //出错将回滚事务
  }finally{
    HibernateUtil.closeSession(session);  //关闭Session对象
  }
}

运行结果如下:
成功加载了实体类Users
成功删除了名称为tsoft的用户

原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/22930.html

(0)
上一篇 2021年7月20日
下一篇 2021年7月20日

相关推荐

发表回复

登录后才能评论