gpt4 book ai didi

java - HQL 查询未删除托管对象

转载 作者:行者123 更新时间:2023-12-02 06:14:34 24 4
gpt4 key购买 nike

我正在开发 Hibernate(3.3.2.GA - 由于该软件应该很快发布,所以没有时间更新)应用程序的继承代码库,我正在尝试从该应用程序中删除一些对象数据库。通过 HQL 查询删除对象后,仍然可以通过(MyEclipse 生成的)dao 的 findById 方法从 hibernate session 中检索对象。我是否缺少任何东西才能让物体消失?我需要使一些缓存失效吗?经过看似随机的一段时间(大约 30 到 300 秒)后,findById 开始返回 null。这些对象使用复合 ID。这会是一个问题吗?

以下是删除对象的代码:

Query query = objDao.getSession()
.createQuery("DELETE FROM Obj i WHERE i.id.uuid = ? AND i.userId = ?");
query.setString(0, obj.getUuid());
query.setInteger(1, currentUserId);
objDao.getSession().beginTransaction();

int numRows = query.executeUpdate();
System.out.println("Deleted " + numRows + " Obj for uuid " + obj.getUuid() + " (user: "
+ currentUserId+ ")");
objDao.getSession().flush();
objDao.getSession().getTransaction().commit();

这是随后调用的代码,用于从数据库中检索对象。我希望它返回 null,但事实并非如此。

objDao.findById(new ObjectId(temp.getId(), temp.getUuid()))

objDao.findById 的实现如下:

public Obj findById(com.application.ObjectId id) {
Obj instance = (Obj) getSession() // this returns a org.hibernate.Session
.get("com.application.Obj", id);
return instance;
}

感谢任何帮助!

最佳答案

不确定您如何获得 session ,但建议执行以下操作:

getSessionFactory().openSession();

这样,您将始终获得新 session ,并且不会返回上一个 session 中缓存的任何内容。

干杯!!

关于java - HQL 查询未删除托管对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18616313/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com