public interface Type
extends java.io.Serializable
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.Modifier and Type | Method and Description |
---|---|
java.lang.Object |
assemble(java.io.Serializable cached,
SharedSessionContractImplementor session,
java.lang.Object owner)
Reconstruct the object from its disassembled state.
|
void |
beforeAssemble(java.io.Serializable cached,
SharedSessionContractImplementor 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(java.lang.Object x,
java.lang.Object y)
Perform a
Comparator style comparison between values |
java.lang.Object |
deepCopy(java.lang.Object value,
SessionFactoryImplementor factory)
Return a deep copy of the persistent state, stopping at entities and at collections.
|
Size[] |
defaultSizes(Mapping mapping)
Defines the column sizes to use according to this type if the user did not explicitly say (and if no
dictatedSizes(org.hibernate.engine.spi.Mapping) were given). |
Size[] |
dictatedSizes(Mapping mapping)
Return the column sizes dictated by this type.
|
java.io.Serializable |
disassemble(java.lang.Object value,
SharedSessionContractImplementor session,
java.lang.Object owner)
Return a disassembled representation of the object.
|
int |
getColumnSpan(Mapping mapping)
How many columns are used to persist this type.
|
int |
getHashCode(java.lang.Object x)
Get a hash code, consistent with persistence "equality".
|
int |
getHashCode(java.lang.Object x,
SessionFactoryImplementor factory)
Get a hash code, consistent with persistence "equality".
|
java.lang.String |
getName()
Returns the abbreviated name of the type.
|
java.lang.Class |
getReturnedClass()
|
Type |
getSemiResolvedType(SessionFactoryImplementor factory)
As part of 2-phase loading, when we perform resolving what is the resolved type for this type? Generally
speaking the type and its semi-resolved type will be the same.
|
java.lang.Object |
hydrate(java.sql.ResultSet rs,
java.lang.String[] names,
SharedSessionContractImplementor session,
java.lang.Object owner)
Extract a value from the JDBC result set.
|
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(java.lang.Object oldState,
java.lang.Object currentState,
boolean[] checkable,
SharedSessionContractImplementor session)
Should the parent be considered dirty, given both the old and current value?
|
boolean |
isDirty(java.lang.Object old,
java.lang.Object current,
SharedSessionContractImplementor 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(java.lang.Object x,
java.lang.Object y)
Compare two instances of the class mapped by this type for persistence "equality" (equality of persistent
state).
|
boolean |
isEqual(java.lang.Object x,
java.lang.Object y,
SessionFactoryImplementor factory)
Compare two instances of the class mapped by this type for persistence "equality" (equality of persistent
state).
|
boolean |
isModified(java.lang.Object dbState,
java.lang.Object currentState,
boolean[] checkable,
SharedSessionContractImplementor 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.spi.SharedSessionContractImplementor) methods is that here we need to account for "partially" built values. |
boolean |
isMutable()
Are objects of this type mutable.
|
boolean |
isSame(java.lang.Object x,
java.lang.Object y)
Compare two instances of the class mapped by this type for persistence "equality" (equality of persistent
state) taking a shortcut for entity references.
|
java.lang.Object |
nullSafeGet(java.sql.ResultSet rs,
java.lang.String[] names,
SharedSessionContractImplementor session,
java.lang.Object owner)
Extract a value of the
mapped class from the JDBC result set. |
java.lang.Object |
nullSafeGet(java.sql.ResultSet rs,
java.lang.String name,
SharedSessionContractImplementor session,
java.lang.Object owner)
Extract a value of the
mapped class from the JDBC result set. |
void |
nullSafeSet(java.sql.PreparedStatement st,
java.lang.Object value,
int index,
boolean[] settable,
SharedSessionContractImplementor session)
Bind a value represented by an instance of the
mapped class to the JDBC prepared
statement, ignoring some columns as dictated by the 'settable' parameter. |
void |
nullSafeSet(java.sql.PreparedStatement st,
java.lang.Object value,
int index,
SharedSessionContractImplementor session)
Bind a value represented by an instance of the
mapped class to the JDBC prepared
statement. |
java.lang.Object |
replace(java.lang.Object original,
java.lang.Object target,
SharedSessionContractImplementor session,
java.lang.Object owner,
java.util.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.
|
java.lang.Object |
replace(java.lang.Object original,
java.lang.Object target,
SharedSessionContractImplementor session,
java.lang.Object owner,
java.util.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.
|
java.lang.Object |
resolve(java.lang.Object value,
SharedSessionContractImplementor session,
java.lang.Object owner) |
default java.lang.Object |
resolve(java.lang.Object value,
SharedSessionContractImplementor session,
java.lang.Object owner,
java.lang.Boolean overridingEager)
The second phase of 2-phase loading.
|
java.lang.Object |
semiResolve(java.lang.Object value,
SharedSessionContractImplementor session,
java.lang.Object owner)
Given a hydrated, but unresolved value, return a value that may be used to reconstruct property-ref
associations.
|
int[] |
sqlTypes(Mapping mapping)
Return the JDBC types codes (per
Types ) for the columns mapped by this type. |
boolean[] |
toColumnNullness(java.lang.Object value,
Mapping mapping)
Given an instance of the type, return an array of boolean, indicating
which mapped columns would be null.
|
java.lang.String |
toLoggableString(java.lang.Object value,
SessionFactoryImplementor factory)
Generate a representation of the value for logging purposes.
|
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 getColumnSpan(Mapping mapping) throws MappingException
sqlTypes(mapping).length
mapping
- The mapping object :/MappingException
- Generally indicates an issue accessing the passed mapping object.int[] sqlTypes(Mapping mapping) throws MappingException
Types
) for the columns mapped by this type.
NOTE: The number of elements in this array matches the return from getColumnSpan(org.hibernate.engine.spi.Mapping)
.mapping
- The mapping object :/MappingException
- Generally indicates an issue accessing the passed mapping object.Size[] dictatedSizes(Mapping mapping) throws MappingException
char
/Character
would
have a dictated length limit of 1; for a string-based UUID
would have a size limit of 36; etc.
NOTE: The number of elements in this array matches the return from getColumnSpan(org.hibernate.engine.spi.Mapping)
.mapping
- The mapping object :/MappingException
- Generally indicates an issue accessing the passed mapping object.Size[] defaultSizes(Mapping mapping) throws MappingException
dictatedSizes(org.hibernate.engine.spi.Mapping)
were given).
NOTE: The number of elements in this array matches the return from getColumnSpan(org.hibernate.engine.spi.Mapping)
.mapping
- The mapping object :/MappingException
- Generally indicates an issue accessing the passed mapping object.java.lang.Class getReturnedClass()
nullSafeGet(java.sql.ResultSet, java.lang.String[], org.hibernate.engine.spi.SharedSessionContractImplementor, java.lang.Object)
methods. This is used to establish the class of an array of
this type.boolean isSame(java.lang.Object x, java.lang.Object y) 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)
x
- The first valuey
- The second valueHibernateException
- A problem occurred performing the comparisonboolean isEqual(java.lang.Object x, java.lang.Object y) throws HibernateException
x
- The first valuey
- The second valueHibernateException
- A problem occurred performing the comparisonboolean isEqual(java.lang.Object x, java.lang.Object y, SessionFactoryImplementor factory) throws HibernateException
x
- The first valuey
- The second valuefactory
- The session factoryHibernateException
- A problem occurred performing the comparisonint getHashCode(java.lang.Object x) throws HibernateException
hashCode
.x
- The value for which to retrieve a hash codeHibernateException
- A problem occurred calculating the hash codeint getHashCode(java.lang.Object x, SessionFactoryImplementor factory) throws HibernateException
hashCode
.x
- The value for which to retrieve a hash codefactory
- The session factoryHibernateException
- A problem occurred calculating the hash codeint compare(java.lang.Object x, java.lang.Object y)
Comparator
style comparison between valuesx
- The first valuey
- The second valueComparator.compare(T, T)
for a discussion.boolean isDirty(java.lang.Object old, java.lang.Object current, SharedSessionContractImplementor 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(java.lang.Object oldState, java.lang.Object currentState, boolean[] checkable, SharedSessionContractImplementor 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(java.lang.Object dbState, java.lang.Object currentState, boolean[] checkable, SharedSessionContractImplementor session) throws HibernateException
isDirty(java.lang.Object, java.lang.Object, org.hibernate.engine.spi.SharedSessionContractImplementor)
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.spi.SharedSessionContractImplementor)
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 checkingjava.lang.Object nullSafeGet(java.sql.ResultSet rs, java.lang.String[] names, SharedSessionContractImplementor session, java.lang.Object owner) throws HibernateException, java.sql.SQLException
mapped class
from the JDBC result set. Implementors
should handle possibility of null values.rs
- The result set from which to extract value.names
- the column names making up this type value (use to read from result set)session
- The originating sessionowner
- the parent entityHibernateException
- An error from Hibernatejava.sql.SQLException
- An error from the JDBC driveralternative, 2-phase property initialization
java.lang.Object nullSafeGet(java.sql.ResultSet rs, java.lang.String name, SharedSessionContractImplementor session, java.lang.Object owner) throws HibernateException, java.sql.SQLException
mapped class
from the JDBC result set. Implementors
should handle possibility of null values. This form might be called if the type is known to be a
single-column type.rs
- The result set from which to extract value.name
- the column name making up this type value (use to read from result set)session
- The originating sessionowner
- the parent entityHibernateException
- An error from Hibernatejava.sql.SQLException
- An error from the JDBC drivervoid nullSafeSet(java.sql.PreparedStatement st, java.lang.Object value, int index, boolean[] settable, SharedSessionContractImplementor session) throws HibernateException, java.sql.SQLException
mapped class
to the JDBC prepared
statement, ignoring some columns as dictated by the 'settable' parameter. Implementors should handle the
possibility of null values. A multi-column type should bind parameters starting from index.st
- The JDBC prepared statement to which to bindvalue
- the object to writeindex
- starting parameter bind indexsettable
- an array indicating which columns to bind/ignoresession
- The originating sessionHibernateException
- An error from Hibernatejava.sql.SQLException
- An error from the JDBC drivervoid nullSafeSet(java.sql.PreparedStatement st, java.lang.Object value, int index, SharedSessionContractImplementor session) throws HibernateException, java.sql.SQLException
mapped class
to the JDBC prepared
statement. Implementors should handle possibility of null values. A multi-column type should bind parameters
starting from index.st
- The JDBC prepared statement to which to bindvalue
- the object to writeindex
- starting parameter bind indexsession
- The originating sessionHibernateException
- An error from Hibernatejava.sql.SQLException
- An error from the JDBC driverjava.lang.String toLoggableString(java.lang.Object value, SessionFactoryImplementor factory) throws HibernateException
value
- The value to be loggedfactory
- The session factoryHibernateException
- An error from Hibernatejava.lang.String getName()
java.lang.Object deepCopy(java.lang.Object value, SessionFactoryImplementor factory) throws HibernateException
value
- The value to be copiedfactory
- The session factoryHibernateException
- An error from Hibernateboolean isMutable()
java.io.Serializable disassemble(java.lang.Object value, SharedSessionContractImplementor session, java.lang.Object owner) throws HibernateException
value
- the value to cachesession
- the originating sessionowner
- optional parent entity object (needed for collections)HibernateException
- An error from Hibernatejava.lang.Object assemble(java.io.Serializable cached, SharedSessionContractImplementor session, java.lang.Object owner) throws HibernateException
disassemble(java.lang.Object, org.hibernate.engine.spi.SharedSessionContractImplementor, java.lang.Object)
cached
- the disassembled state from the cachesession
- the originating sessionowner
- the parent entity objectHibernateException
- An error from Hibernatevoid beforeAssemble(java.io.Serializable cached, SharedSessionContractImplementor session)
cached
- The keysession
- The originating sessionjava.lang.Object hydrate(java.sql.ResultSet rs, java.lang.String[] names, SharedSessionContractImplementor session, java.lang.Object owner) throws HibernateException, java.sql.SQLException
resolve(java.lang.Object, org.hibernate.engine.spi.SharedSessionContractImplementor, java.lang.Object)
This hydrated value will be either:rs
- The JDBC result setnames
- the column names making up this type value (use to read from result set)session
- The originating sessionowner
- the parent entityHibernateException
- An error from Hibernatejava.sql.SQLException
- An error from the JDBC driverresolve(java.lang.Object, org.hibernate.engine.spi.SharedSessionContractImplementor, java.lang.Object)
java.lang.Object resolve(java.lang.Object value, SharedSessionContractImplementor session, java.lang.Object owner) throws HibernateException
default java.lang.Object resolve(java.lang.Object value, SharedSessionContractImplementor session, java.lang.Object owner, java.lang.Boolean overridingEager) throws HibernateException
value
- an identifier or value returned by hydrate()owner
- the parent entitysession
- the sessionoverridingEager
- can override eager from the mapping. For example because of LoadQueryInfluencers
If null, then it does not override. If true or false then it overrides the mapping value.HibernateException
- An error from Hibernatehydrate(java.sql.ResultSet, java.lang.String[], org.hibernate.engine.spi.SharedSessionContractImplementor, java.lang.Object)
java.lang.Object semiResolve(java.lang.Object value, SharedSessionContractImplementor session, java.lang.Object owner) throws HibernateException
value
- The unresolved, hydrated valuesession
- THe originating sessionowner
- The value ownerHibernateException
- An error from HibernateType getSemiResolvedType(SessionFactoryImplementor factory)
factory
- The session factoryjava.lang.Object replace(java.lang.Object original, java.lang.Object target, SharedSessionContractImplementor session, java.lang.Object owner, java.util.Map copyCache) throws HibernateException
original
- the value from the detached entity being mergedtarget
- the value in the managed entitysession
- The originating sessionowner
- The owner of the valuecopyCache
- The cache of already copied/replaced valuesHibernateException
- An error from Hibernatejava.lang.Object replace(java.lang.Object original, java.lang.Object target, SharedSessionContractImplementor session, java.lang.Object owner, java.util.Map copyCache, ForeignKeyDirection foreignKeyDirection) throws HibernateException
original
- the value from the detached entity being mergedtarget
- the value in the managed entitysession
- The originating sessionowner
- The owner of the valuecopyCache
- The cache of already copied/replaced valuesforeignKeyDirection
- For associations, which direction does the foreign key point?HibernateException
- An error from Hibernateboolean[] toColumnNullness(java.lang.Object value, Mapping mapping)
value
- an instance of the typemapping
- The mapping abstractionCopyright © 2001-2018 Red Hat, Inc. All Rights Reserved.