Hibernate Session.delete() 一个对象(如果存在)

2022-09-02 11:53:40

在会话类的 JavaDoc 中,删除方法的描述是:

从数据存储中移除持久性实例。该参数可以是与接收会话关联的实例,也可以是具有与现有持久状态关联的标识符的瞬态实例。

我的问题是:

  1. 我想删除一个分离对象,我可以使用这种方法,AFAIK会话首先使一个对象从分离中持久化,然后执行其操作。我说的对吗?
  2. 如果我不确定数据库中是否存在该对象,我应该使用Session.get()来检查它是否为空,然后执行删除操作,还是可以使用直接删除操作?

下面是一个代码片段:

public void removeUnallocatedUserIfExits(final long itemId) {
    getHibernateTemplate().execute(new HibernateCallback() {

        public Object doInHibernate(Session session) throws HibernateException, SQLException {
            session.flush();
            session.setCacheMode(CacheMode.IGNORE);
            UnallocatedUser unallocatedUser;
            if ((unallocatedUser = (UnallocatedUser) session.get(UnallocatedUser.class, itemId)) != null) {
                session.delete(unallocatedUser);
            }
            session.flush();
            return null;
        }
    });
}

可以吗?


答案 1

或具有与现有持久性状态关联的标识符的瞬态实例

这意味着您可以直接将 to 传递给 ,以便删除该对象。此外,您无需检查实体是否存在。如果在数据库中找不到任何记录,则应该存在异常。事实上,我们通常不会真正得到这个案例。我们总是删除一个现有的实体,我的意思是通常的逻辑就是这样;所以,没有必要这样做。你可以简单地做到这一点,entitysession.delete()

SomeEntity ent = session.load(SomeEntity.class, '1234');
session.delete(ent);

或者你可以这样做,

SomeEntity ent = new SomeEntity('1234'); // used constructor for brevity
session.delete(ent);

顺便说一句,您也可以使用此版本,session.delete(String query)

sess.delete("from Employee e where e.id = '1234'"); // Just found it is deprecated

答案 2
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class DeletePersistentObjectWithHibernate {

public static void main(String[] args) {

        SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();

        Session session = sessionFactory.getCurrentSession();

        long id = 2;

        try {
            session.beginTransaction();

            Employee employee = (Employee) session.get(Employee.class, id);

            session.delete(employee);

            session.getTransaction().commit();
        }
        catch (HibernateException e) {
            e.printStackTrace();
            session.getTransaction().rollback();
        }

    }

}

推荐