diff options
Diffstat (limited to 'jpa/plugins/org.eclipse.jpt.jpa.core/src/org/eclipse/jpt/jpa/core/jpql/spi/JpaMapping.java')
-rw-r--r-- | jpa/plugins/org.eclipse.jpt.jpa.core/src/org/eclipse/jpt/jpa/core/jpql/spi/JpaMapping.java | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/jpa/plugins/org.eclipse.jpt.jpa.core/src/org/eclipse/jpt/jpa/core/jpql/spi/JpaMapping.java b/jpa/plugins/org.eclipse.jpt.jpa.core/src/org/eclipse/jpt/jpa/core/jpql/spi/JpaMapping.java index 0ae0971e4e..05c50266ac 100644 --- a/jpa/plugins/org.eclipse.jpt.jpa.core/src/org/eclipse/jpt/jpa/core/jpql/spi/JpaMapping.java +++ b/jpa/plugins/org.eclipse.jpt.jpa.core/src/org/eclipse/jpt/jpa/core/jpql/spi/JpaMapping.java @@ -26,6 +26,7 @@ import org.eclipse.jpt.jpa.core.context.PersistentAttribute; import org.eclipse.jpt.jpa.core.context.RelationshipMapping; import org.eclipse.jpt.jpa.core.context.java.JavaPersistentAttribute; import org.eclipse.jpt.jpa.core.jpa2.MappingKeys2_0; +import org.eclipse.jpt.jpa.core.jpa2.context.ElementCollectionMapping2_0; import org.eclipse.persistence.jpa.jpql.spi.IEntity; import org.eclipse.persistence.jpa.jpql.spi.IManagedType; import org.eclipse.persistence.jpa.jpql.spi.IMapping; @@ -123,12 +124,20 @@ public abstract class JpaMapping implements IMapping { // For relationship mapping, make sure to check the target entity first if (isRelationship()) { - String entityName = ((RelationshipMapping) mapping).getTargetEntity(); - - if (StringTools.stringIsNotEmpty(entityName)) { - IEntity entity = getParent().getProvider().getEntityNamed(entityName); - if (entity != null) { - return entity.getType(); + if (mappingType == ELEMENT_COLLECTION) { + String targetClass = ((ElementCollectionMapping2_0) mapping).getTargetClass(); + if (StringTools.stringIsNotEmpty(targetClass)) { + return getTypeRepository().getType(targetClass); + } + } + else { + String entityName = ((RelationshipMapping) mapping).getTargetEntity(); + + if (StringTools.stringIsNotEmpty(entityName)) { + IEntity entity = getParent().getProvider().getEntityNamed(entityName); + if (entity != null) { + return entity.getType(); + } } } } |