reloading a detached object with a collection fails

Description

Hi,

1) I have a simple object <O> with a collection loaded and use <version> for both (no second level cache)
2) The object <O> is associated with session A, via <O> = load(CLASS, <ID>)
3) The session <A> is later closed because e.g. an exception occurs
4) Another session is opened later on, session B
5) If load(<O>, <ID>) is called an NonUniqueObjectException is thrown
(a different object with the same identifier value was already associated with the session)
6) If instead I use the session.refresh(<O>) no exception is thrown, the object is reloaded ok.

It seems this issue might be related with:
http://opensource.atlassian.com/projects/hibernate/browse/HHH-511
but i cannot be sure.

Part of the stacktrace:

org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: [gr.metadata.orthomed.db.Patient#23]
at org.hibernate.event.def.DefaultLoadEventListener.load(DefaultLoadEventListener.java:132)
at org.hibernate.event.def.DefaultLoadEventListener.returnNarrowedProxy(DefaultLoadEventListener.java:202)
at org.hibernate.event.def.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:169)
at org.hibernate.event.def.DefaultLoadEventListener.onLoad(DefaultLoadEventListener.java:87)
at org.hibernate.impl.SessionImpl.fireLoad(SessionImpl.java:862)
at org.hibernate.impl.SessionImpl.load(SessionImpl.java:770)
at gr.metadata.lib.hibernate.HibernateHelper.reloadObject(HibernateHelper.java:230)

Attachments

1

Activity

Show:

Steve EbersoleMarch 21, 2011 at 7:05 PM

Bulk closing stale resolved issues

Gregory KotsaftisJune 7, 2008 at 7:02 PM

Hi,

it's been almost 2 years and still not a simple response to this issue.
Why? Is it so hard to provide a simple answer where this issue will or wont be fixed?

Please reopen this issue or reply why it is closed.

Gregory KotsaftisSeptember 29, 2006 at 10:04 PM

I created a very small app to demonstrate the problem.
Though I cannot reproduce the "NonUniqueObjectException" another exception which should be related occurs.

The "aliases.conf" should be placed inside FireBird root folder.
The db schema is in "tables.sql".

toggle the boolean "USE_REFRESH" inside main() in order to verify that the reloading works if I use refresh().

Please let me know if there is anything else you need.

Christian BauerSeptember 29, 2006 at 7:00 PM

It means Incomplete. Read this again: http://www.hibernate.org/217.html

Gregory KotsaftisSeptember 29, 2006 at 6:41 PM

Sorry, I cannot understand the status change to "Resolved / Incomplete"
does this mean this issue is resolved in the latest 3.2BETA ?

Incomplete

Details

Assignee

Reporter

Affects versions

Priority

Created September 29, 2006 at 11:33 AM
Updated March 21, 2011 at 7:05 PM
Resolved September 29, 2006 at 12:12 PM