Class SimpleNaturalIdMapping
- java.lang.Object
-
- org.hibernate.metamodel.mapping.internal.AbstractNaturalIdMapping
-
- org.hibernate.metamodel.mapping.internal.SimpleNaturalIdMapping
-
- All Implemented Interfaces:
Bindable,JdbcMappingContainer,MappingModelExpressible,ModelPart,NaturalIdMapping,VirtualModelPart,JavaType.CoercionContext
public class SimpleNaturalIdMapping extends AbstractNaturalIdMapping implements JavaType.CoercionContext
Single-attribute NaturalIdMapping implementation
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.hibernate.metamodel.mapping.Bindable
Bindable.JdbcValuesBiConsumer<X,Y>, Bindable.JdbcValuesConsumer
-
Nested classes/interfaces inherited from interface org.hibernate.metamodel.mapping.ModelPart
ModelPart.JdbcValueBiConsumer<X,Y>, ModelPart.JdbcValueConsumer
-
-
Field Summary
-
Fields inherited from interface org.hibernate.metamodel.mapping.NaturalIdMapping
PART_NAME
-
-
Constructor Summary
Constructors Constructor Description SimpleNaturalIdMapping(SingularAttributeMapping attribute, EntityMappingType declaringType, MappingModelCreationProcess creationProcess)
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaddToCacheKey(MutableCacheKeyBuilder cacheKey, Object value, SharedSessionContractImplementor session)Add to the MutableCacheKey the values obtained disassembling the value and the hasCode generated from the disassembled value.voidapplySqlSelections(NavigablePath navigablePath, TableGroup tableGroup, DomainResultCreationState creationState)Apply SQL selections for a specific reference to this ModelPart outside the domain query's root select clause.voidapplySqlSelections(NavigablePath navigablePath, TableGroup tableGroup, DomainResultCreationState creationState, BiConsumer<SqlSelection,JdbcMapping> selectionConsumer)Apply SQL selections for a specific reference to this ModelPart outside the domain query's root select clause.AttributeMappingasAttributeMapping()<X,Y>
intbreakDownJdbcValues(Object domainValue, int offset, X x, Y y, ModelPart.JdbcValueBiConsumer<X,Y> valueConsumer, SharedSessionContractImplementor session)Breaks down the domain value to its constituent JDBC values.intcalculateHashCode(Object value)Calculate the hash-code of a natural-id value<T> DomainResult<T>createDomainResult(NavigablePath navigablePath, TableGroup tableGroup, String resultVariable, DomainResultCreationState creationState)Create a DomainResult for a specific reference to this ModelPart.Objectdisassemble(Object value, SharedSessionContractImplementor session)ObjectextractNaturalIdFromEntity(Object entity)Given an entity instance, extract the normalized natural id representationObjectextractNaturalIdFromEntityState(Object[] state)Given an array of "full entity state", extract the normalized natural id representation<X,Y>
intforEachDisassembledJdbcValue(Object value, int offset, X x, Y y, Bindable.JdbcValuesBiConsumer<X,Y> valuesConsumer, SharedSessionContractImplementor session)LikeBindable.forEachDisassembledJdbcValue(Object, Object, Object, JdbcValuesBiConsumer, SharedSessionContractImplementor), but additionally receives an offset by which the selectionIndex is incremented when callingBindable.JdbcValuesBiConsumer.consume(int, Object, Object, Object, JdbcMapping).intforEachJdbcType(int offset, IndexedConsumer<JdbcMapping> action)Visit each JdbcMapping starting from the given offset<X,Y>
intforEachJdbcValue(Object value, int offset, X x, Y y, Bindable.JdbcValuesBiConsumer<X,Y> valuesConsumer, SharedSessionContractImplementor session)Visit each constituent JDBC value extracted from the entity instance itself.intforEachSelectable(int offset, SelectableConsumer consumer)Visits each selectable mapping with the selectable index offset by the given value.SingularAttributeMappinggetAttribute()JavaType<?>getJavaType()The Java type for this part.JdbcMappinggetJdbcMapping(int index)List<JdbcMapping>getJdbcMappings()Deprecated, for removal: This API element is subject to removal in a future version.intgetJdbcTypeCount()The number of JDBC mappingsList<SingularAttributeMapping>getNaturalIdAttributes()The attribute(s) making up the natural-id.MappingTypegetPartMappingType()The type for this part.JdbcMappinggetSingleJdbcMapping()TypeConfigurationgetTypeConfiguration()booleanhasPartitionedSelectionMapping()NaturalIdLoader<?>makeLoader(EntityMappingType entityDescriptor)Make a loader capable of loading a single entity by natural-idMultiNaturalIdLoader<?>makeMultiLoader(EntityMappingType entityDescriptor)Make a loader capable of loading multiple entities by natural-idObjectnormalizeIncomingValue(Object naturalIdToLoad)ObjectnormalizeInput(Object incoming)Normalize a user-provided natural-id value into the representation Hibernate uses internallyvoidvalidateInternalForm(Object naturalIdValue)Validates a natural id value(s) for the described natural-id based on the expected internal representationvoidverifyFlushState(Object id, Object[] currentState, Object[] loadedState, SharedSessionContractImplementor session)Verify the natural-id value(s) we are about to flush to the database-
Methods inherited from class org.hibernate.metamodel.mapping.internal.AbstractNaturalIdMapping
findContainingEntityMapping, getCacheAccess, getDeclaringType, getNavigableRole, isMutable
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.hibernate.metamodel.mapping.Bindable
forEachDisassembledJdbcValue, forEachDisassembledJdbcValue, forEachDisassembledJdbcValue, forEachJdbcType, forEachJdbcValue, forEachJdbcValue, forEachJdbcValue
-
Methods inherited from interface org.hibernate.metamodel.mapping.ModelPart
areEqual, asBasicValuedModelPart, asEntityMappingType, breakDownJdbcValues, decompose, decompose, forEachSelectable, isEntityIdentifierMapping
-
Methods inherited from interface org.hibernate.metamodel.mapping.NaturalIdMapping
getPartName
-
Methods inherited from interface org.hibernate.metamodel.mapping.VirtualModelPart
isVirtual
-
-
-
-
Constructor Detail
-
SimpleNaturalIdMapping
public SimpleNaturalIdMapping(SingularAttributeMapping attribute, EntityMappingType declaringType, MappingModelCreationProcess creationProcess)
-
-
Method Detail
-
getAttribute
public SingularAttributeMapping getAttribute()
-
verifyFlushState
public void verifyFlushState(Object id, Object[] currentState, Object[] loadedState, SharedSessionContractImplementor session)
Description copied from interface:NaturalIdMappingVerify the natural-id value(s) we are about to flush to the database- Specified by:
verifyFlushStatein interfaceNaturalIdMapping
-
extractNaturalIdFromEntityState
public Object extractNaturalIdFromEntityState(Object[] state)
Description copied from interface:NaturalIdMappingGiven an array of "full entity state", extract the normalized natural id representation- Specified by:
extractNaturalIdFromEntityStatein interfaceNaturalIdMapping- Parameters:
state- The attribute state array- Returns:
- The extracted natural id values. This is a normalized
-
extractNaturalIdFromEntity
public Object extractNaturalIdFromEntity(Object entity)
Description copied from interface:NaturalIdMappingGiven an entity instance, extract the normalized natural id representation- Specified by:
extractNaturalIdFromEntityin interfaceNaturalIdMapping- Parameters:
entity- The entity instance- Returns:
- The extracted natural id values
-
validateInternalForm
public void validateInternalForm(Object naturalIdValue)
Description copied from interface:NaturalIdMappingValidates a natural id value(s) for the described natural-id based on the expected internal representation- Specified by:
validateInternalFormin interfaceNaturalIdMapping
-
calculateHashCode
public int calculateHashCode(Object value)
Description copied from interface:NaturalIdMappingCalculate the hash-code of a natural-id value- Specified by:
calculateHashCodein interfaceNaturalIdMapping- Parameters:
value- The natural-id value- Returns:
- The hash-code
-
normalizeInput
public Object normalizeInput(Object incoming)
Description copied from interface:NaturalIdMappingNormalize a user-provided natural-id value into the representation Hibernate uses internally- Specified by:
normalizeInputin interfaceNaturalIdMapping- Parameters:
incoming- The user-supplied value- Returns:
- The normalized, internal representation
-
getNaturalIdAttributes
public List<SingularAttributeMapping> getNaturalIdAttributes()
Description copied from interface:NaturalIdMappingThe attribute(s) making up the natural-id.- Specified by:
getNaturalIdAttributesin interfaceNaturalIdMapping
-
getPartMappingType
public MappingType getPartMappingType()
Description copied from interface:ModelPartThe type for this part.- Specified by:
getPartMappingTypein interfaceModelPart
-
getJavaType
public JavaType<?> getJavaType()
Description copied from interface:ModelPartThe Java type for this part. Generally equivalent toMappingType.getMappedJavaType()relative toModelPart.getPartMappingType()- Specified by:
getJavaTypein interfaceModelPart
-
createDomainResult
public <T> DomainResult<T> createDomainResult(NavigablePath navigablePath, TableGroup tableGroup, String resultVariable, DomainResultCreationState creationState)
Description copied from interface:ModelPartCreate a DomainResult for a specific reference to this ModelPart.- Specified by:
createDomainResultin interfaceModelPart
-
applySqlSelections
public void applySqlSelections(NavigablePath navigablePath, TableGroup tableGroup, DomainResultCreationState creationState)
Description copied from interface:ModelPartApply SQL selections for a specific reference to this ModelPart outside the domain query's root select clause.- Specified by:
applySqlSelectionsin interfaceModelPart
-
applySqlSelections
public void applySqlSelections(NavigablePath navigablePath, TableGroup tableGroup, DomainResultCreationState creationState, BiConsumer<SqlSelection,JdbcMapping> selectionConsumer)
Description copied from interface:ModelPartApply SQL selections for a specific reference to this ModelPart outside the domain query's root select clause.- Specified by:
applySqlSelectionsin interfaceModelPart
-
forEachSelectable
public int forEachSelectable(int offset, SelectableConsumer consumer)Description copied from interface:ModelPartVisits each selectable mapping with the selectable index offset by the given value. Returns the amount of jdbc types that have been visited.- Specified by:
forEachSelectablein interfaceModelPart
-
getJdbcTypeCount
public int getJdbcTypeCount()
Description copied from interface:BindableThe number of JDBC mappings- Specified by:
getJdbcTypeCountin interfaceBindable- Specified by:
getJdbcTypeCountin interfaceJdbcMappingContainer
-
getJdbcMappings
@Deprecated(forRemoval=true) public List<JdbcMapping> getJdbcMappings()
Deprecated, for removal: This API element is subject to removal in a future version.Description copied from interface:BindableThe list of JDBC mappings- Specified by:
getJdbcMappingsin interfaceBindable- Specified by:
getJdbcMappingsin interfaceJdbcMappingContainer
-
getJdbcMapping
public JdbcMapping getJdbcMapping(int index)
- Specified by:
getJdbcMappingin interfaceJdbcMappingContainer
-
getSingleJdbcMapping
public JdbcMapping getSingleJdbcMapping()
- Specified by:
getSingleJdbcMappingin interfaceJdbcMappingContainer
-
forEachJdbcType
public int forEachJdbcType(int offset, IndexedConsumer<JdbcMapping> action)Description copied from interface:JdbcMappingContainerVisit each JdbcMapping starting from the given offset- Specified by:
forEachJdbcTypein interfaceJdbcMappingContainer
-
disassemble
public Object disassemble(Object value, SharedSessionContractImplementor session)
- Specified by:
disassemblein interfaceBindable- See Also:
As an example, consider the following domain model: ````
-
addToCacheKey
public void addToCacheKey(MutableCacheKeyBuilder cacheKey, Object value, SharedSessionContractImplementor session)
Description copied from interface:BindableAdd to the MutableCacheKey the values obtained disassembling the value and the hasCode generated from the disassembled value.- Specified by:
addToCacheKeyin interfaceBindable- Parameters:
cacheKey- the MutableCacheKey used to add the disassembled value and the hashCodevalue- the value to disassemblesession- the SharedSessionContractImplementor
-
breakDownJdbcValues
public <X,Y> int breakDownJdbcValues(Object domainValue, int offset, X x, Y y, ModelPart.JdbcValueBiConsumer<X,Y> valueConsumer, SharedSessionContractImplementor session)
Description copied from interface:ModelPartBreaks down the domain value to its constituent JDBC values. Think of it as breaking the multi-dimensional array into a visitable flat array. Additionally, it passes through the valuesXandYto the consumer. Returns the amount of jdbc types that have been visited.- Specified by:
breakDownJdbcValuesin interfaceModelPart
-
forEachDisassembledJdbcValue
public <X,Y> int forEachDisassembledJdbcValue(Object value, int offset, X x, Y y, Bindable.JdbcValuesBiConsumer<X,Y> valuesConsumer, SharedSessionContractImplementor session)
Description copied from interface:BindableLikeBindable.forEachDisassembledJdbcValue(Object, Object, Object, JdbcValuesBiConsumer, SharedSessionContractImplementor), but additionally receives an offset by which the selectionIndex is incremented when callingBindable.JdbcValuesBiConsumer.consume(int, Object, Object, Object, JdbcMapping).- Specified by:
forEachDisassembledJdbcValuein interfaceBindable
-
forEachJdbcValue
public <X,Y> int forEachJdbcValue(Object value, int offset, X x, Y y, Bindable.JdbcValuesBiConsumer<X,Y> valuesConsumer, SharedSessionContractImplementor session)
Description copied from interface:BindableVisit each constituent JDBC value extracted from the entity instance itself. Short-hand form of callingBindable.disassemble(java.lang.Object, org.hibernate.engine.spi.SharedSessionContractImplementor)and piping its result toBindable.forEachDisassembledJdbcValue(Object, int, JdbcValuesConsumer, SharedSessionContractImplementor)- Specified by:
forEachJdbcValuein interfaceBindable
-
makeLoader
public NaturalIdLoader<?> makeLoader(EntityMappingType entityDescriptor)
Description copied from interface:NaturalIdMappingMake a loader capable of loading a single entity by natural-id- Specified by:
makeLoaderin interfaceNaturalIdMapping
-
makeMultiLoader
public MultiNaturalIdLoader<?> makeMultiLoader(EntityMappingType entityDescriptor)
Description copied from interface:NaturalIdMappingMake a loader capable of loading multiple entities by natural-id- Specified by:
makeMultiLoaderin interfaceNaturalIdMapping
-
getTypeConfiguration
public TypeConfiguration getTypeConfiguration()
- Specified by:
getTypeConfigurationin interfaceJavaType.CoercionContext
-
asAttributeMapping
public AttributeMapping asAttributeMapping()
- Specified by:
asAttributeMappingin interfaceModelPart
-
hasPartitionedSelectionMapping
public boolean hasPartitionedSelectionMapping()
- Specified by:
hasPartitionedSelectionMappingin interfaceModelPart
-
-