|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
public interface Type
Defines a mapping between a Java type and one or more JDBC types, as well as describing the in-memory semantics of the given java type (how do we check it for 'dirtiness', how do we copy values, etc).
Application developers needing custom types can implement this interface (either directly or via subclassing an existing impl) or by the (slightly more stable, though more limited)UserType
interface.
Implementations of this interface must certainly be thread-safe. It is recommended that they be immutable as
well, though that is difficult to achieve completely given the no-arg constructor requirement for custom types.
Method Summary | |
---|---|
Object |
assemble(Serializable cached,
SessionImplementor session,
Object owner)
Reconstruct the object from its cached "disassembled" state. |
void |
beforeAssemble(Serializable cached,
SessionImplementor session)
Called before assembling a query result set from the query cache, to allow batch fetching of entities missing from the second-level cache. |
int |
compare(Object x,
Object y,
EntityMode entityMode)
Perform a Comparator style comparison between values |
Object |
deepCopy(Object value,
EntityMode entityMode,
SessionFactoryImplementor factory)
Return a deep copy of the persistent state, stopping at entities and at collections. |
Serializable |
disassemble(Object value,
SessionImplementor session,
Object owner)
Return a cacheable "disassembled" representation of the object. |
Object |
fromXMLNode(org.dom4j.Node xml,
Mapping factory)
Parse the XML representation of an instance. |
int |
getColumnSpan(Mapping mapping)
How many columns are used to persist this type. |
int |
getHashCode(Object x,
EntityMode entityMode)
Get a hash code, consistent with persistence "equality". |
int |
getHashCode(Object x,
EntityMode entityMode,
SessionFactoryImplementor factory)
Get a hash code, consistent with persistence "equality". |
String |
getName()
Returns the abbreviated name of the type. |
Class |
getReturnedClass()
The class returned by nullSafeGet(java.sql.ResultSet, java.lang.String[], org.hibernate.engine.SessionImplementor, java.lang.Object) methods. |
Type |
getSemiResolvedType(SessionFactoryImplementor factory)
Get the type of a semi-resolved value. |
Object |
hydrate(ResultSet rs,
String[] names,
SessionImplementor session,
Object owner)
Retrieve an instance of the mapped class, or the identifier of an entity or collection, from a JDBC resultset. |
boolean |
isAnyType()
Return true if the implementation is castable to AnyType . |
boolean |
isAssociationType()
Return true if the implementation is castable to AssociationType . |
boolean |
isCollectionType()
Return true if the implementation is castable to CollectionType . |
boolean |
isComponentType()
Return true if the implementation is castable to CompositeType . |
boolean |
isDirty(Object oldState,
Object currentState,
boolean[] checkable,
SessionImplementor session)
Should the parent be considered dirty, given both the old and current value? |
boolean |
isDirty(Object old,
Object current,
SessionImplementor session)
Should the parent be considered dirty, given both the old and current value? |
boolean |
isEntityType()
Return true if the implementation is castable to EntityType . |
boolean |
isEqual(Object x,
Object y,
EntityMode entityMode)
Compare two instances of the class mapped by this type for persistence "equality" (equality of persistent state). |
boolean |
isEqual(Object x,
Object y,
EntityMode entityMode,
SessionFactoryImplementor factory)
Compare two instances of the class mapped by this type for persistence "equality" (equality of persistent state). |
boolean |
isModified(Object dbState,
Object currentState,
boolean[] checkable,
SessionImplementor session)
Has the value been modified compared to the current database state? The difference between this and the isDirty(java.lang.Object, java.lang.Object, org.hibernate.engine.SessionImplementor) methods is that here we need to account for "partially" built values. |
boolean |
isMutable()
Are objects of this type mutable. |
boolean |
isSame(Object x,
Object y,
EntityMode entityMode)
Compare two instances of the class mapped by this type for persistence "equality" (equality of persistent state) taking a shortcut for entity references. |
boolean |
isXMLElement()
|
Object |
nullSafeGet(ResultSet rs,
String[] names,
SessionImplementor session,
Object owner)
Retrieve an instance of the mapped class from a JDBC resultset. |
Object |
nullSafeGet(ResultSet rs,
String name,
SessionImplementor session,
Object owner)
Retrieve an instance of the mapped class from a JDBC resultset. |
void |
nullSafeSet(PreparedStatement st,
Object value,
int index,
boolean[] settable,
SessionImplementor session)
Write an instance of the mapped class to a prepared statement, ignoring some columns. |
void |
nullSafeSet(PreparedStatement st,
Object value,
int index,
SessionImplementor session)
Write an instance of the mapped class to a prepared statement. |
Object |
replace(Object original,
Object target,
SessionImplementor session,
Object owner,
Map copyCache)
During merge, replace the existing (target) value in the entity we are merging to with a new (original) value from the detached entity we are merging. |
Object |
replace(Object original,
Object target,
SessionImplementor session,
Object owner,
Map copyCache,
ForeignKeyDirection foreignKeyDirection)
During merge, replace the existing (target) value in the entity we are merging to with a new (original) value from the detached entity we are merging. |
Object |
resolve(Object value,
SessionImplementor session,
Object owner)
Map identifiers to entities or collections. |
Object |
semiResolve(Object value,
SessionImplementor session,
Object owner)
Given a hydrated, but unresolved value, return a value that may be used to reconstruct property-ref associations. |
void |
setToXMLNode(org.dom4j.Node node,
Object value,
SessionFactoryImplementor factory)
A representation of the value to be embedded in an XML element. |
int[] |
sqlTypes(Mapping mapping)
Return the JDBC types codes (per Types ) for the columns mapped by this type. |
boolean[] |
toColumnNullness(Object value,
Mapping mapping)
Given an instance of the type, return an array of boolean, indicating which mapped columns would be null. |
String |
toLoggableString(Object value,
SessionFactoryImplementor factory)
A representation of the value to be embedded in a log file. |
Method Detail |
---|
boolean isAssociationType()
AssociationType
. This does not necessarily imply that
the type actually represents an association. Essentially a polymorphic version of
(type instanceof AssociationType.class)
AssociationType
implementor; false otherwise.boolean isCollectionType()
CollectionType
. Essentially a polymorphic version of
(type instanceof CollectionType.class)
A CollectionType
is additionally an AssociationType
; so if this method returns true,
isAssociationType()
should also return true.
CollectionType
implementor; false otherwise.boolean isEntityType()
EntityType
. Essentially a polymorphic
version of (type instanceof EntityType.class)
.
An EntityType
is additionally an AssociationType
; so if this method returns true,
isAssociationType()
should also return true.
EntityType
implementor; false otherwise.boolean isAnyType()
AnyType
. Essentially a polymorphic
version of (type instanceof AnyType.class)
.
An AnyType
is additionally an AssociationType
; so if this method returns true,
isAssociationType()
should also return true.
AnyType
implementor; false otherwise.boolean isComponentType()
CompositeType
. Essentially a polymorphic
version of (type instanceof CompositeType.class)
. A component type may own collections or
associations and hence must provide certain extra functionality.
CompositeType
implementor; false otherwise.int[] sqlTypes(Mapping mapping) throws MappingException
Types
) for the columns mapped by this type.
mapping
- The mapping object :/
MappingException
- Generally indicates an issue accessing the passed mapping object.int getColumnSpan(Mapping mapping) throws MappingException
sqlTypes(mapping).length
mapping
- The mapping object :/
MappingException
- Generally indicates an issue accessing the passed mapping object.Class getReturnedClass()
nullSafeGet(java.sql.ResultSet, java.lang.String[], org.hibernate.engine.SessionImplementor, java.lang.Object)
methods. This is used to establish the class of an array of
this type.
boolean isXMLElement()
boolean isSame(Object x, Object y, EntityMode entityMode) throws HibernateException
#equals
check on the values. For associations the implication
is a bit different. For most types it is conceivable to simply delegate to isEqual(java.lang.Object, java.lang.Object, org.hibernate.EntityMode)
x
- The first valuey
- The second valueentityMode
- The entity mode of the values.
HibernateException
- A problem occurred performing the comparisonboolean isEqual(Object x, Object y, EntityMode entityMode) throws HibernateException
x
- The first valuey
- The second valueentityMode
- The entity mode of the values.
HibernateException
- A problem occurred performing the comparisonboolean isEqual(Object x, Object y, EntityMode entityMode, SessionFactoryImplementor factory) throws HibernateException
x
- The first valuey
- The second valueentityMode
- The entity mode of the values.factory
- The session factory
HibernateException
- A problem occurred performing the comparisonint getHashCode(Object x, EntityMode entityMode) throws HibernateException
#hashCode
.
x
- The value for which to retrieve a hash codeentityMode
- The entity mode of the value.
HibernateException
- A problem occurred calculating the hash codeint getHashCode(Object x, EntityMode entityMode, SessionFactoryImplementor factory) throws HibernateException
#hashCode
.
x
- The value for which to retrieve a hash codeentityMode
- The entity mode of the value.factory
- The session factory
HibernateException
- A problem occurred calculating the hash codeint compare(Object x, Object y, EntityMode entityMode)
Comparator
style comparison between values
x
- The first valuey
- The second valueentityMode
- The entity mode of the values.
Comparator.compare(T, T)
for a discussion.boolean isDirty(Object old, Object current, SessionImplementor session) throws HibernateException
old
- the old valuecurrent
- the current valuesession
- The session from which the request originated.
HibernateException
- A problem occurred performing the checkingboolean isDirty(Object oldState, Object currentState, boolean[] checkable, SessionImplementor session) throws HibernateException
oldState
- the old valuecurrentState
- the current valuecheckable
- An array of booleans indicating which columns making up the value are actually checkablesession
- The session from which the request originated.
HibernateException
- A problem occurred performing the checkingboolean isModified(Object dbState, Object currentState, boolean[] checkable, SessionImplementor session) throws HibernateException
isDirty(java.lang.Object, java.lang.Object, org.hibernate.engine.SessionImplementor)
methods is that here we need to account for "partially" built values. This is really
only an issue with association types. For most type implementations it is enough to simply delegate to
isDirty(java.lang.Object, java.lang.Object, org.hibernate.engine.SessionImplementor)
here/
dbState
- the database state, in a "hydrated" form, with identifiers unresolvedcurrentState
- the current state of the objectcheckable
- which columns are actually updatablesession
- The session from which the request originated.
HibernateException
- A problem occurred performing the checkingObject nullSafeGet(ResultSet rs, String[] names, SessionImplementor session, Object owner) throws HibernateException, SQLException
rs
- names
- the column namessession
- owner
- the parent entity
HibernateException
SQLException
alternative, 2-phase property initialization
Object nullSafeGet(ResultSet rs, String name, SessionImplementor session, Object owner) throws HibernateException, SQLException
rs
- name
- the column namesession
- owner
- the parent entity
HibernateException
SQLException
void nullSafeSet(PreparedStatement st, Object value, int index, boolean[] settable, SessionImplementor session) throws HibernateException, SQLException
st
- value
- the object to writeindex
- statement parameter indexsettable
- an array indicating which columns to ignoresession
-
HibernateException
SQLException
void nullSafeSet(PreparedStatement st, Object value, int index, SessionImplementor session) throws HibernateException, SQLException
st
- value
- the object to writeindex
- statement parameter indexsession
-
HibernateException
SQLException
void setToXMLNode(org.dom4j.Node node, Object value, SessionFactoryImplementor factory) throws HibernateException
value
- factory
-
HibernateException
String toLoggableString(Object value, SessionFactoryImplementor factory) throws HibernateException
value
- factory
-
HibernateException
Object fromXMLNode(org.dom4j.Node xml, Mapping factory) throws HibernateException
xml
- factory
-
HibernateException
String getName()
Object deepCopy(Object value, EntityMode entityMode, SessionFactoryImplementor factory) throws HibernateException
value
- generally a collection element or entity fieldentityMode
- factory
-
HibernateException
boolean isMutable()
Serializable disassemble(Object value, SessionImplementor session, Object owner) throws HibernateException
value
- the value to cachesession
- the sessionowner
- optional parent entity object (needed for collections)
HibernateException
Object assemble(Serializable cached, SessionImplementor session, Object owner) throws HibernateException
cached
- the disassembled state from the cachesession
- the sessionowner
- the parent entity object
HibernateException
void beforeAssemble(Serializable cached, SessionImplementor session)
Object hydrate(ResultSet rs, String[] names, SessionImplementor session, Object owner) throws HibernateException, SQLException
rs
- names
- the column namessession
- the sessionowner
- the parent entity
HibernateException
SQLException
resolve(Object, SessionImplementor, Object)
Object resolve(Object value, SessionImplementor session, Object owner) throws HibernateException
value
- an identifier or value returned by hydrate()owner
- the parent entitysession
- the session
HibernateException
hydrate(ResultSet, String[], SessionImplementor, Object)
Object semiResolve(Object value, SessionImplementor session, Object owner) throws HibernateException
HibernateException
Type getSemiResolvedType(SessionFactoryImplementor factory)
Object replace(Object original, Object target, SessionImplementor session, Object owner, Map copyCache) throws HibernateException
original
- the value from the detached entity being mergedtarget
- the value in the managed entity
HibernateException
Object replace(Object original, Object target, SessionImplementor session, Object owner, Map copyCache, ForeignKeyDirection foreignKeyDirection) throws HibernateException
original
- the value from the detached entity being mergedtarget
- the value in the managed entity
HibernateException
boolean[] toColumnNullness(Object value, Mapping mapping)
value
- an instance of the type
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |