diff --git a/hibernate-core/src/main/java/org/hibernate/metamodel/mapping/internal/EmbeddableMappingTypeImpl.java b/hibernate-core/src/main/java/org/hibernate/metamodel/mapping/internal/EmbeddableMappingTypeImpl.java index f486cd2b11..d4fe1bfd7f 100644 --- a/hibernate-core/src/main/java/org/hibernate/metamodel/mapping/internal/EmbeddableMappingTypeImpl.java +++ b/hibernate-core/src/main/java/org/hibernate/metamodel/mapping/internal/EmbeddableMappingTypeImpl.java @@ -634,31 +634,35 @@ public class EmbeddableMappingTypeImpl extends AbstractEmbeddableMapping impleme for ( int i = 0; i < size; i++ ) { final AttributeMapping attributeMapping = attributeMappings.get( i ); - final Object attributeValue = values[ i ]; - span += attributeMapping.breakDownJdbcValues( - attributeValue, - offset + span, - x, - y, - valueConsumer, - session - ); + if ( !attributeMapping.isPluralAttributeMapping() ) { + final Object attributeValue = values[i]; + span += attributeMapping.breakDownJdbcValues( + attributeValue, + offset + span, + x, + y, + valueConsumer, + session + ); + } } } else { for ( int i = 0; i < size; i++ ) { final AttributeMapping attributeMapping = attributeMappings.get( i ); - final Object attributeValue = domainValue == null - ? null - : attributeMapping.getPropertyAccess().getGetter().get( domainValue ); - span += attributeMapping.breakDownJdbcValues( - attributeValue, - offset + span, - x, - y, - valueConsumer, - session - ); + if ( !attributeMapping.isPluralAttributeMapping() ) { + final Object attributeValue = domainValue == null + ? null + : attributeMapping.getPropertyAccess().getGetter().get( domainValue ); + span += attributeMapping.breakDownJdbcValues( + attributeValue, + offset + span, + x, + y, + valueConsumer, + session + ); + } } } return span; diff --git a/hibernate-core/src/main/java/org/hibernate/persister/entity/mutation/DeleteCoordinator.java b/hibernate-core/src/main/java/org/hibernate/persister/entity/mutation/DeleteCoordinator.java index ef60792ac7..e7f28996b6 100644 --- a/hibernate-core/src/main/java/org/hibernate/persister/entity/mutation/DeleteCoordinator.java +++ b/hibernate-core/src/main/java/org/hibernate/persister/entity/mutation/DeleteCoordinator.java @@ -165,7 +165,7 @@ public class DeleteCoordinator extends AbstractMutationCoordinator { for ( int attributeIndex = 0; attributeIndex < versionability.length; attributeIndex++ ) { final AttributeMapping attribute; // only makes sense to lock on singular attributes which are not excluded from optimistic locking - if ( versionability[attributeIndex] && ( attribute = persister.getAttributeMapping( attributeIndex ) ) instanceof SingularAttributeMapping ) { + if ( versionability[attributeIndex] && !( attribute = persister.getAttributeMapping( attributeIndex ) ).isPluralAttributeMapping() ) { final Object loadedValue = loadedState[attributeIndex]; if ( loadedValue != null ) { final String mutationTableName = persister.getAttributeMutationTableName( attributeIndex ); @@ -424,7 +424,7 @@ public class DeleteCoordinator extends AbstractMutationCoordinator { for ( int attributeIndex = 0; attributeIndex < versionability.length; attributeIndex++ ) { final AttributeMapping attribute; // only makes sense to lock on singular attributes which are not excluded from optimistic locking - if ( versionability[attributeIndex] && ( attribute = persister.getAttributeMapping( attributeIndex ) ) instanceof SingularAttributeMapping ) { + if ( versionability[attributeIndex] && !( attribute = persister.getAttributeMapping( attributeIndex ) ).isPluralAttributeMapping() ) { breakDownJdbcValues( mutationGroupBuilder, session, attribute, loadedState[attributeIndex] ); } }