org.hibernate.type
Class MutableType
java.lang.Object
org.hibernate.type.AbstractType
org.hibernate.type.NullableType
org.hibernate.type.MutableType
- All Implemented Interfaces:
- Serializable, Type
- Direct Known Subclasses:
- AbstractBynaryType, AbstractCharArrayType, CalendarDateType, CalendarType, DateType, SerializableType, TimestampType, TimeType
public abstract class MutableType
- extends NullableType
Superclass for mutable nullable types
- Author:
- Gavin King
- See Also:
- Serialized Form
Methods inherited from class org.hibernate.type.NullableType |
fromStringValue, fromXMLNode, fromXMLString, get, getColumnSpan, isDirty, isEqual, isEqual, nullSafeGet, nullSafeGet, nullSafeGet, nullSafeGet, nullSafeSet, nullSafeSet, nullSafeSet, nullSafeToString, set, setToXMLNode, sqlType, sqlTypes, toColumnNullness, toLoggableString, toString, toXMLString |
Methods inherited from class org.hibernate.type.AbstractType |
assemble, beforeAssemble, compare, disassemble, getHashCode, getHashCode, getSemiResolvedType, hydrate, isAnyType, isAssociationType, isCollectionType, isComponentType, isDirty, isEntityType, isEqual, isModified, isSame, isXMLElement, replace, replaceNode, resolve, semiResolve |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
MutableType
public MutableType()
isMutable
public final boolean isMutable()
- Description copied from interface:
Type
- Are objects of this type mutable. (With respect to the referencing object ...
entities and collections are considered immutable because they manage their
own internal state.)
- Returns:
- boolean
deepCopyNotNull
protected abstract Object deepCopyNotNull(Object value)
throws HibernateException
- Throws:
HibernateException
deepCopy
public final Object deepCopy(Object value,
EntityMode entityMode,
SessionFactoryImplementor factory)
throws HibernateException
- Description copied from interface:
Type
- Return a deep copy of the persistent state, stopping at entities and at
collections.
- Parameters:
value
- generally a collection element or entity field
- Returns:
- Object a copy
- Throws:
HibernateException
replace
public Object replace(Object original,
Object target,
SessionImplementor session,
Object owner,
Map copyCache)
throws HibernateException
- Description copied from interface:
Type
- 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. For immutable
objects, or null values, it is safe to simply return the first parameter. For
mutable objects, it is safe to return a copy of the first parameter. For objects
with component values, it might make sense to recursively replace component values.
- Parameters:
original
- the value from the detached entity being mergedtarget
- the value in the managed entity
- Returns:
- the value to be merged
- Throws:
HibernateException