diff --git a/hibernate-envers/src/main/java/org/hibernate/envers/internal/entities/mapper/relation/ToOneIdMapper.java b/hibernate-envers/src/main/java/org/hibernate/envers/internal/entities/mapper/relation/ToOneIdMapper.java index d1c6d0836b..d532cf7ac7 100644 --- a/hibernate-envers/src/main/java/org/hibernate/envers/internal/entities/mapper/relation/ToOneIdMapper.java +++ b/hibernate-envers/src/main/java/org/hibernate/envers/internal/entities/mapper/relation/ToOneIdMapper.java @@ -104,7 +104,15 @@ public class ToOneIdMapper extends AbstractToOneMapper { boolean ignoreNotFound = false; if ( !referencedEntity.isAudited() ) { final String referencingEntityName = enversService.getEntitiesConfigurations().getEntityNameForVersionsEntityName( (String) data.get( "$type$" ) ); - ignoreNotFound = enversService.getEntitiesConfigurations().getRelationDescription( referencingEntityName, getPropertyData().getName() ).isIgnoreNotFound(); + if ( referencingEntityName == null && primaryKey == null ) { + // HHH-11215 - Fix for NPE when Embeddable with ManyToOne inside ElementCollection + // an embeddable in an element-collection + // todo: perhaps the mapper should account for this instead? + ignoreNotFound = true; + } + else { + ignoreNotFound = enversService.getEntitiesConfigurations().getRelationDescription( referencingEntityName, getPropertyData().getName() ).isIgnoreNotFound(); + } } if ( ignoreNotFound ) { // Eagerly loading referenced entity to silence potential (in case of proxy)