[Hibernate-JIRA] Created: (HHH-2135) Hibernate Deserialization: In org.hibernate.type.SerializableType the code makes a test for the return of a null object by simply testing the object as to whether or not it is null.
by Lamon Gray (JIRA)
Hibernate Deserialization: In org.hibernate.type.SerializableType the code makes a test for the return of a null object by simply testing the object as to whether or not it is null.
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Key: HHH-2135
URL: http://opensource.atlassian.com/projects/hibernate/browse/HHH-2135
Project: Hibernate3
Type: Improvement
Versions: 3.2.0.cr5
Environment: HIbernate 3.2.1 & NCR TeradataJBOss 4.0.x & JBoss Cache 1.2.4
Reporter: Lamon Gray
In org.hibernate.type.SerializableType the code makes a test for the return of a null object by simply testing the object as to whether or not it is null.
public Object get(ResultSet rs, String name) throws HibernateException, SQLException {
byte[] bytes = (byte[]) Hibernate.BINARY.get(rs, name);
if ( bytes==null) {
return null;
}
else {
return fromBytes(bytes);
}
}
Fairly reasonable, however in my testing of the Teradata dialect i am finding that often the value in the column is null but that the return is coming back as an empty array. The following code would seem to be a bit more robust in my opinion:
public Object get(ResultSet rs, String name) throws HibernateException, SQLException {
byte[] bytes = (byte[]) Hibernate.BINARY.get(rs, name);
if ( bytes==null || Array.getLength(bytes)==0) {
return null;
}
else {
return fromBytes(bytes);
}
}
Can someone tell me if this is done this way for a reason? Or maybe the JDBC driver is returning the incorrect value (IE. it should be returning a null value as opposed to an empty array)?
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
http://opensource.atlassian.com/projects/hibernate/secure/Administrators....
-
For more information on JIRA, see:
http://www.atlassian.com/software/jira
18 years, 2 months
[Hibernate-JIRA] Updated: (HHH-1265) classcastexception when using dom4jsession to save xml of a versioned class
by Jeremiah Marcum (JIRA)
[ http://opensource.atlassian.com/projects/hibernate/browse/HHH-1265?page=all ]
Jeremiah Marcum updated HHH-1265:
---------------------------------
Attachment: patches.zip
The patches I described previously attached in a zip file.
> classcastexception when using dom4jsession to save xml of a versioned class
> ---------------------------------------------------------------------------
>
> Key: HHH-1265
> URL: http://opensource.atlassian.com/projects/hibernate/browse/HHH-1265
> Project: Hibernate3
> Type: Bug
> Components: core
> Versions: 3.1, 3.1 beta 2
> Environment: hibernate 3.1 oracle windows
> Reporter: Winston Huang
> Attachments: hibernate_test.zip, patches.zip
>
>
> when importing from xml format and trying to save the instance using dom4jsession, i got the following exception. it would succeed if i don't use an optimistic locking object (with versioning). see the attached test case for details. i have a many-to-many set relationship from user to role. the xml data files are in User.xml and Role.xml. loading Role.xml is fine. but loading User.xml failed.
> log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment).
> log4j:WARN Please initialize the log4j system properly.
> Exception in thread "main" java.lang.ClassCastException: org.dom4j.tree.DefaultElement
> at org.hibernate.event.def.DirtyCollectionSearchVisitor.processCollection(DirtyCollectionSearchVisitor.java:50)
> at org.hibernate.event.def.AbstractVisitor.processValue(AbstractVisitor.java:104)
> at org.hibernate.event.def.AbstractVisitor.processValue(AbstractVisitor.java:64)
> at org.hibernate.event.def.AbstractVisitor.processEntityPropertyValues(AbstractVisitor.java:58)
> at org.hibernate.event.def.DefaultFlushEntityEventListener.isUpdateNecessary(DefaultFlushEntityEventListener.java:301)
> at org.hibernate.event.def.DefaultFlushEntityEventListener.onFlushEntity(DefaultFlushEntityEventListener.java:111)
> at org.hibernate.event.def.AbstractFlushingEventListener.flushEntities(AbstractFlushingEventListener.java:190)
> at org.hibernate.event.def.AbstractFlushingEventListener.flushEverythingToExecutions(AbstractFlushingEventListener.java:70)
> at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:26)
> at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:730)
> at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:329)
> at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:86)
> at TestDom4jVersionedObject.main(TestDom4jVersionedObject.java:26)
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
http://opensource.atlassian.com/projects/hibernate/secure/Administrators....
-
For more information on JIRA, see:
http://www.atlassian.com/software/jira
18 years, 2 months
[Hibernate-JIRA] Commented: (HHH-1265) classcastexception when using dom4jsession to save xml of a versioned class
by Jeremiah Marcum (JIRA)
[ http://opensource.atlassian.com/projects/hibernate/browse/HHH-1265?page=c... ]
Jeremiah Marcum commented on HHH-1265:
--------------------------------------
I was also having this problem and was able to fix it by patching the following 2 files:
Note: I changed DirtyCollectionVisitor.java by adding ' || collection instanceof Element' to the if statement. It may be more appropriate to add ' || !(collection instanceof PersistentCollection) to the if statement so that any collection that needs to be wrapped by its Holder will work instead of just doing that for Elements.
Note2: I had to patch Dom4jAccessor.java because it was returning my id as the actual serializable (Long in my case) and not as an element, which was throwing a CCE. This may be because my id was specified as an attribute and not as an element, i'm not sure. Whatever the reason, adding that change fixed it, however it may be better to look further up the line to see what the cause is.
Patch for org.hibernate.event.def.DirtyCollectionSearchVisitor.java
Index: DirtyCollectionSearchVisitor.java
===================================================================
--- DirtyCollectionSearchVisitor.java (revision 10687)
+++ DirtyCollectionSearchVisitor.java (working copy)
@@ -37,7 +37,7 @@
SessionImplementor session = getSession();
final PersistentCollection persistentCollection;
- if ( type.isArrayType() ) {
+ if ( type.isArrayType() || collection instanceof Element ) {
persistentCollection = session.getPersistenceContext().getCollectionHolder(collection);
// if no array holder we found an unwrappered array (this can't occur,
// because we now always call wrap() before getting to here)
Patch for Dom4jAccessor.java
Index: Dom4jAccessor.java
===================================================================
--- Dom4jAccessor.java (revision 10687)
+++ Dom4jAccessor.java (working copy)
@@ -168,6 +168,7 @@
}
public Object get(Object owner) throws HibernateException {
+ if (!(owner instanceof Element)) { return owner; } //EARLY RETURN
Element ownerElement = (Element) owner;
Node attribute = ownerElement.attribute(attributeName);
return attribute==null ? null :
> classcastexception when using dom4jsession to save xml of a versioned class
> ---------------------------------------------------------------------------
>
> Key: HHH-1265
> URL: http://opensource.atlassian.com/projects/hibernate/browse/HHH-1265
> Project: Hibernate3
> Type: Bug
> Components: core
> Versions: 3.1, 3.1 beta 2
> Environment: hibernate 3.1 oracle windows
> Reporter: Winston Huang
> Attachments: hibernate_test.zip, patches.zip
>
>
> when importing from xml format and trying to save the instance using dom4jsession, i got the following exception. it would succeed if i don't use an optimistic locking object (with versioning). see the attached test case for details. i have a many-to-many set relationship from user to role. the xml data files are in User.xml and Role.xml. loading Role.xml is fine. but loading User.xml failed.
> log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment).
> log4j:WARN Please initialize the log4j system properly.
> Exception in thread "main" java.lang.ClassCastException: org.dom4j.tree.DefaultElement
> at org.hibernate.event.def.DirtyCollectionSearchVisitor.processCollection(DirtyCollectionSearchVisitor.java:50)
> at org.hibernate.event.def.AbstractVisitor.processValue(AbstractVisitor.java:104)
> at org.hibernate.event.def.AbstractVisitor.processValue(AbstractVisitor.java:64)
> at org.hibernate.event.def.AbstractVisitor.processEntityPropertyValues(AbstractVisitor.java:58)
> at org.hibernate.event.def.DefaultFlushEntityEventListener.isUpdateNecessary(DefaultFlushEntityEventListener.java:301)
> at org.hibernate.event.def.DefaultFlushEntityEventListener.onFlushEntity(DefaultFlushEntityEventListener.java:111)
> at org.hibernate.event.def.AbstractFlushingEventListener.flushEntities(AbstractFlushingEventListener.java:190)
> at org.hibernate.event.def.AbstractFlushingEventListener.flushEverythingToExecutions(AbstractFlushingEventListener.java:70)
> at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:26)
> at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:730)
> at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:329)
> at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:86)
> at TestDom4jVersionedObject.main(TestDom4jVersionedObject.java:26)
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
http://opensource.atlassian.com/projects/hibernate/secure/Administrators....
-
For more information on JIRA, see:
http://www.atlassian.com/software/jira
18 years, 2 months