HHH-16574 Return treat type as path source for treated joins

This commit is contained in:
Marco Belladelli 2023-05-22 10:25:25 +02:00
parent 03fd7c7e0b
commit e4dae1b319
No known key found for this signature in database
GPG Key ID: D1D0C3030AE3AA35
21 changed files with 112 additions and 127 deletions

View File

@ -178,8 +178,15 @@ public class QualifiedJoinPathConsumer implements DotIdentifierConsumer {
boolean isTerminal, boolean isTerminal,
boolean allowReuse, boolean allowReuse,
SqmCreationState creationState) { SqmCreationState creationState) {
final SqmPathSource<?> referencedPathSource = lhs.getReferencedPathSource();
// We need to use referencedPathSource when it is not generic since the getResolvedModel() method would
// return the association attribute as a path source and for treated paths that might correspond to a
// different entity type (usually the first in alphabetical order) and not the correct treat target
final SqmPathSource<?> pathSource = referencedPathSource.isGeneric() ?
lhs.getResolvedModel() :
referencedPathSource;
//noinspection unchecked //noinspection unchecked
final SqmPathSource<Object> subPathSource = (SqmPathSource<Object>) lhs.getReferencedPathSource().getSubPathSource( name ); final SqmPathSource<Object> subPathSource = (SqmPathSource<Object>) pathSource.getSubPathSource( name );
if ( allowReuse && !isTerminal ) { if ( allowReuse && !isTerminal ) {
for ( SqmJoin<?, ?> sqmJoin : lhs.getSqmJoins() ) { for ( SqmJoin<?, ?> sqmJoin : lhs.getSqmJoins() ) {
if ( sqmJoin.getAlias() == null && sqmJoin.getReferencedPathSource() == subPathSource ) { if ( sqmJoin.getAlias() == null && sqmJoin.getReferencedPathSource() == subPathSource ) {

View File

@ -746,7 +746,7 @@ public class QuerySplitter {
final SqmBagJoin copy = new SqmBagJoin<>( final SqmBagJoin copy = new SqmBagJoin<>(
findSqmFromCopy( join.getLhs() ), findSqmFromCopy( join.getLhs() ),
join.getReferencedPathSource(), join.getAttribute(),
join.getExplicitAlias(), join.getExplicitAlias(),
join.getSqmJoinType(), join.getSqmJoinType(),
join.isFetched(), join.isFetched(),
@ -846,7 +846,7 @@ public class QuerySplitter {
final SqmListJoin copy = new SqmListJoin<>( final SqmListJoin copy = new SqmListJoin<>(
findSqmFromCopy( join.getLhs() ), findSqmFromCopy( join.getLhs() ),
join.getReferencedPathSource(), join.getAttribute(),
join.getExplicitAlias(), join.getExplicitAlias(),
join.getSqmJoinType(), join.getSqmJoinType(),
join.isFetched(), join.isFetched(),
@ -867,7 +867,7 @@ public class QuerySplitter {
final SqmMapJoin copy = new SqmMapJoin<>( final SqmMapJoin copy = new SqmMapJoin<>(
findSqmFromCopy( join.getLhs() ), findSqmFromCopy( join.getLhs() ),
join.getReferencedPathSource(), join.getAttribute(),
join.getExplicitAlias(), join.getExplicitAlias(),
join.getSqmJoinType(), join.getSqmJoinType(),
join.isFetched(), join.isFetched(),
@ -888,7 +888,7 @@ public class QuerySplitter {
final SqmSetJoin copy = new SqmSetJoin<>( final SqmSetJoin copy = new SqmSetJoin<>(
findSqmFromCopy( join.getLhs() ), findSqmFromCopy( join.getLhs() ),
join.getReferencedPathSource(), join.getAttribute(),
join.getExplicitAlias(), join.getExplicitAlias(),
join.getSqmJoinType(), join.getSqmJoinType(),
join.isFetched(), join.isFetched(),
@ -909,7 +909,7 @@ public class QuerySplitter {
final SqmSingularJoin copy = new SqmSingularJoin<>( final SqmSingularJoin copy = new SqmSingularJoin<>(
findSqmFromCopy( join.getLhs() ), findSqmFromCopy( join.getLhs() ),
join.getReferencedPathSource(), join.getAttribute(),
join.getExplicitAlias(), join.getExplicitAlias(),
join.getSqmJoinType(), join.getSqmJoinType(),
join.isFetched(), join.isFetched(),

View File

@ -2796,12 +2796,39 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
log.tracef( "Resolved SqmRoot [%s] to new TableGroup [%s]", sqmRoot, tableGroup ); log.tracef( "Resolved SqmRoot [%s] to new TableGroup [%s]", sqmRoot, tableGroup );
fromClauseIndex.register( sqmRoot, tableGroup ); registerSqmFromTableGroup( sqmRoot, tableGroup );
currentQuerySpec.getFromClause().addRoot( tableGroup ); currentQuerySpec.getFromClause().addRoot( tableGroup );
consumeJoins( sqmRoot, fromClauseIndex, tableGroup ); consumeJoins( sqmRoot, fromClauseIndex, tableGroup );
} }
private void registerSqmFromTableGroup(SqmFrom<?, ?> sqmFrom, TableGroup tableGroup) {
getFromClauseIndex().register( sqmFrom, tableGroup );
// We also need to register the table group for the treats
if ( tableGroup instanceof PluralTableGroup ) {
final PluralTableGroup pluralTableGroup = (PluralTableGroup) tableGroup;
for ( SqmFrom<?, ?> sqmTreat : sqmFrom.getSqmTreats() ) {
if ( pluralTableGroup.getElementTableGroup() != null ) {
getFromClauseAccess().registerTableGroup(
sqmTreat.getNavigablePath().append( CollectionPart.Nature.ELEMENT.getName() ),
pluralTableGroup.getElementTableGroup()
);
}
if ( pluralTableGroup.getIndexTableGroup() != null ) {
getFromClauseAccess().registerTableGroup(
sqmTreat.getNavigablePath().append( CollectionPart.Nature.INDEX.getName() ),
pluralTableGroup.getIndexTableGroup()
);
}
}
}
else {
for ( SqmFrom<?, ?> sqmTreat : sqmFrom.getSqmTreats() ) {
getFromClauseAccess().registerTableGroup( sqmTreat.getNavigablePath(), tableGroup );
}
}
}
private TableGroup createCteTableGroup( private TableGroup createCteTableGroup(
String cteName, String cteName,
NavigablePath navigablePath, NavigablePath navigablePath,
@ -3290,34 +3317,8 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
lhsTableGroup.addTableGroupJoin( joinedTableGroupJoin ); lhsTableGroup.addTableGroupJoin( joinedTableGroupJoin );
getFromClauseIndex().register( sqmJoin, joinedTableGroup ); registerSqmFromTableGroup( sqmJoin, joinedTableGroup );
registerPluralTableGroupParts( joinedTableGroup ); registerPluralTableGroupParts( joinedTableGroup );
// For joins, we also need to register the table groups for the treats
if ( joinedTableGroup instanceof PluralTableGroup ) {
final PluralTableGroup pluralTableGroup = (PluralTableGroup) joinedTableGroup;
for ( SqmFrom<?, ?> sqmTreat : sqmJoin.getSqmTreats() ) {
if ( pluralTableGroup.getElementTableGroup() != null ) {
getFromClauseAccess().registerTableGroup(
sqmTreat.getNavigablePath().append( CollectionPart.Nature.ELEMENT.getName() ),
pluralTableGroup.getElementTableGroup()
);
}
if ( pluralTableGroup.getIndexTableGroup() != null ) {
getFromClauseAccess().registerTableGroup(
sqmTreat.getNavigablePath().append( CollectionPart.Nature.INDEX.getName() ),
pluralTableGroup.getIndexTableGroup()
);
}
}
}
else {
for ( SqmFrom<?, ?> sqmTreat : sqmJoin.getSqmTreats() ) {
getFromClauseAccess().registerTableGroup(
sqmTreat.getNavigablePath(),
joinedTableGroup
);
}
}
if ( sqmJoin.isFetched() ) { if ( sqmJoin.isFetched() ) {
// A fetch is like a projection usage, so register that properly // A fetch is like a projection usage, so register that properly
registerEntityNameProjectionUsage( sqmJoin, getActualTableGroup( joinedTableGroup, sqmJoin ) ); registerEntityNameProjectionUsage( sqmJoin, getActualTableGroup( joinedTableGroup, sqmJoin ) );
@ -3372,7 +3373,7 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
lhsTableGroup.addTableGroupJoin( tableGroupJoin ); lhsTableGroup.addTableGroupJoin( tableGroupJoin );
getFromClauseIndex().register( sqmJoin, tableGroup ); registerSqmFromTableGroup( sqmJoin, tableGroup );
if ( transitive ) { if ( transitive ) {
consumeExplicitJoins( sqmJoin, tableGroupJoin.getJoinedGroup() ); consumeExplicitJoins( sqmJoin, tableGroupJoin.getJoinedGroup() );
@ -3393,7 +3394,7 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
() -> p -> predicate.set( combinePredicates( predicate.get(), p ) ), () -> p -> predicate.set( combinePredicates( predicate.get(), p ) ),
this this
); );
getFromClauseIndex().register( sqmJoin, tableGroup ); registerSqmFromTableGroup( sqmJoin, tableGroup );
final TableGroupJoin tableGroupJoin = new TableGroupJoin( final TableGroupJoin tableGroupJoin = new TableGroupJoin(
sqmJoin.getNavigablePath(), sqmJoin.getNavigablePath(),
@ -5148,10 +5149,13 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
} }
private Predicate createTreatTypeRestriction(SqmPath<?> lhs, EntityDomainType<?> treatTarget) { private Predicate createTreatTypeRestriction(SqmPath<?> lhs, EntityDomainType<?> treatTarget) {
final EntityPersister entityDescriptor = domainModel.findEntityDescriptor( treatTarget.getHibernateEntityName() ); final AbstractEntityPersister entityDescriptor = (AbstractEntityPersister) domainModel.findEntityDescriptor( treatTarget.getHibernateEntityName() );
if ( entityDescriptor.isPolymorphic() ) {
final Set<String> subclassEntityNames = entityDescriptor.getSubclassEntityNames(); final Set<String> subclassEntityNames = entityDescriptor.getSubclassEntityNames();
return createTreatTypeRestriction( lhs, subclassEntityNames ); return createTreatTypeRestriction( lhs, subclassEntityNames );
} }
return null;
}
private Predicate createTreatTypeRestriction(SqmPath<?> lhs, Set<String> subclassEntityNames) { private Predicate createTreatTypeRestriction(SqmPath<?> lhs, Set<String> subclassEntityNames) {
// Do what visitSelfInterpretingSqmPath does, except for calling preparingReusablePath // Do what visitSelfInterpretingSqmPath does, except for calling preparingReusablePath

View File

@ -188,7 +188,7 @@ public abstract class AbstractSqmPath<T> extends AbstractSqmExpression<T> implem
protected <X> SqmPath<X> resolvePath(String attributeName, SqmPathSource<X> pathSource) { protected <X> SqmPath<X> resolvePath(String attributeName, SqmPathSource<X> pathSource) {
if ( reusablePaths == null ) { if ( reusablePaths == null ) {
reusablePaths = new HashMap<>(); reusablePaths = new HashMap<>();
final SqmPath<X> path = pathSource.createSqmPath( this, getReferencedPathSource().getIntermediatePathSource( pathSource ) ); final SqmPath<X> path = pathSource.createSqmPath( this, getResolvedModel().getIntermediatePathSource( pathSource ) );
reusablePaths.put( attributeName, path ); reusablePaths.put( attributeName, path );
return path; return path;
} }
@ -196,7 +196,7 @@ public abstract class AbstractSqmPath<T> extends AbstractSqmExpression<T> implem
//noinspection unchecked //noinspection unchecked
return (SqmPath<X>) reusablePaths.computeIfAbsent( return (SqmPath<X>) reusablePaths.computeIfAbsent(
attributeName, attributeName,
name -> pathSource.createSqmPath( this, getReferencedPathSource().getIntermediatePathSource( pathSource ) ) name -> pathSource.createSqmPath( this, getResolvedModel().getIntermediatePathSource( pathSource ) )
); );
} }
} }

View File

@ -41,13 +41,8 @@ public abstract class AbstractSqmPluralJoin<O,C,E> extends AbstractSqmAttributeJ
super( lhs, navigablePath, joinedNavigable, alias, joinType, fetched, nodeBuilder ); super( lhs, navigablePath, joinedNavigable, alias, joinType, fetched, nodeBuilder );
} }
@Override
public PluralPersistentAttribute<O, C, E> getReferencedPathSource() {
return (PluralPersistentAttribute<O, C, E>) super.getReferencedPathSource();
}
@Override @Override
public PluralPersistentAttribute<O, C, E> getModel() { public PluralPersistentAttribute<O, C, E> getModel() {
return getReferencedPathSource(); return (PluralPersistentAttribute<O, C, E>) super.getNodeType();
} }
} }

View File

@ -61,7 +61,7 @@ public class SqmBagJoin<O, E> extends AbstractSqmPluralJoin<O,Collection<E>, E>
new SqmBagJoin<>( new SqmBagJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getNavigablePath(), getNavigablePath(),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -72,14 +72,9 @@ public class SqmBagJoin<O, E> extends AbstractSqmPluralJoin<O,Collection<E>, E>
return path; return path;
} }
@Override
public BagPersistentAttribute<O,E> getReferencedPathSource() {
return (BagPersistentAttribute<O,E>) super.getReferencedPathSource();
}
@Override @Override
public BagPersistentAttribute<O,E> getModel() { public BagPersistentAttribute<O,E> getModel() {
return getReferencedPathSource(); return (BagPersistentAttribute<O, E>) super.getModel();
} }
@Override @Override
@ -89,8 +84,7 @@ public class SqmBagJoin<O, E> extends AbstractSqmPluralJoin<O,Collection<E>, E>
@Override @Override
public BagPersistentAttribute<O,E> getAttribute() { public BagPersistentAttribute<O,E> getAttribute() {
//noinspection unchecked return getModel();
return (BagPersistentAttribute<O, E>) super.getAttribute();
} }
@Override @Override
@ -148,12 +142,11 @@ public class SqmBagJoin<O, E> extends AbstractSqmPluralJoin<O,Collection<E>, E>
public SqmAttributeJoin<O, E> makeCopy(SqmCreationProcessingState creationProcessingState) { public SqmAttributeJoin<O, E> makeCopy(SqmCreationProcessingState creationProcessingState) {
return new SqmBagJoin<>( return new SqmBagJoin<>(
creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ), creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
nodeBuilder() nodeBuilder()
); );
} }
} }

View File

@ -62,7 +62,7 @@ public class SqmCorrelatedBagJoin<O, T> extends SqmBagJoin<O, T> implements SqmC
this, this,
new SqmCorrelatedBagJoin<>( new SqmCorrelatedBagJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -105,7 +105,7 @@ public class SqmCorrelatedBagJoin<O, T> extends SqmBagJoin<O, T> implements SqmC
final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry(); final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry();
return new SqmCorrelatedBagJoin<>( return new SqmCorrelatedBagJoin<>(
pathRegistry.findFromByPath( getLhs().getNavigablePath() ), pathRegistry.findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),

View File

@ -62,7 +62,7 @@ public class SqmCorrelatedListJoin<O, T> extends SqmListJoin<O, T> implements Sq
this, this,
new SqmCorrelatedListJoin<>( new SqmCorrelatedListJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -100,7 +100,7 @@ public class SqmCorrelatedListJoin<O, T> extends SqmListJoin<O, T> implements Sq
final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry(); final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry();
return new SqmCorrelatedListJoin<>( return new SqmCorrelatedListJoin<>(
pathRegistry.findFromByPath( getLhs().getNavigablePath() ), pathRegistry.findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),

View File

@ -62,7 +62,7 @@ public class SqmCorrelatedMapJoin<O, K, V> extends SqmMapJoin<O, K, V> implement
this, this,
new SqmCorrelatedMapJoin<>( new SqmCorrelatedMapJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -100,7 +100,7 @@ public class SqmCorrelatedMapJoin<O, K, V> extends SqmMapJoin<O, K, V> implement
final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry(); final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry();
return new SqmCorrelatedMapJoin<>( return new SqmCorrelatedMapJoin<>(
pathRegistry.findFromByPath( getLhs().getNavigablePath() ), pathRegistry.findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),

View File

@ -62,7 +62,7 @@ public class SqmCorrelatedSetJoin<O, T> extends SqmSetJoin<O, T> implements SqmC
this, this,
new SqmCorrelatedSetJoin<>( new SqmCorrelatedSetJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -100,7 +100,7 @@ public class SqmCorrelatedSetJoin<O, T> extends SqmSetJoin<O, T> implements SqmC
final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry(); final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry();
return new SqmCorrelatedSetJoin<>( return new SqmCorrelatedSetJoin<>(
pathRegistry.findFromByPath( getLhs().getNavigablePath() ), pathRegistry.findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),

View File

@ -62,7 +62,7 @@ public class SqmCorrelatedSingularJoin<O, T> extends SqmSingularJoin<O, T> imple
this, this,
new SqmCorrelatedSingularJoin<>( new SqmCorrelatedSingularJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -100,7 +100,7 @@ public class SqmCorrelatedSingularJoin<O, T> extends SqmSingularJoin<O, T> imple
final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry(); final SqmPathRegistry pathRegistry = creationProcessingState.getPathRegistry();
return new SqmCorrelatedSingularJoin<>( return new SqmCorrelatedSingularJoin<>(
pathRegistry.findFromByPath( getLhs().getNavigablePath() ), pathRegistry.findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),

View File

@ -64,7 +64,7 @@ public class SqmListJoin<O,E>
new SqmListJoin<>( new SqmListJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getNavigablePath(), getNavigablePath(),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -75,14 +75,9 @@ public class SqmListJoin<O,E>
return path; return path;
} }
@Override
public ListPersistentAttribute<O, E> getReferencedPathSource() {
return (ListPersistentAttribute<O, E>) super.getReferencedPathSource();
}
@Override @Override
public ListPersistentAttribute<O, E> getModel() { public ListPersistentAttribute<O, E> getModel() {
return getReferencedPathSource(); return (ListPersistentAttribute<O, E>) super.getModel();
} }
@Override @Override
@ -92,13 +87,12 @@ public class SqmListJoin<O,E>
@Override @Override
public ListPersistentAttribute<O,E> getAttribute() { public ListPersistentAttribute<O,E> getAttribute() {
//noinspection unchecked return getModel();
return (ListPersistentAttribute<O, E>) super.getAttribute();
} }
@Override @Override
public SqmPath<Integer> index() { public SqmPath<Integer> index() {
final SqmPathSource<Integer> indexPathSource = getReferencedPathSource().getIndexPathSource(); final SqmPathSource<Integer> indexPathSource = getAttribute().getIndexPathSource();
return resolvePath( indexPathSource.getPathName(), indexPathSource ); return resolvePath( indexPathSource.getPathName(), indexPathSource );
} }
@ -155,7 +149,7 @@ public class SqmListJoin<O,E>
public SqmAttributeJoin<O, E> makeCopy(SqmCreationProcessingState creationProcessingState) { public SqmAttributeJoin<O, E> makeCopy(SqmCreationProcessingState creationProcessingState) {
return new SqmListJoin<>( return new SqmListJoin<>(
creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ), creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),

View File

@ -63,7 +63,7 @@ public class SqmMapJoin<O, K, V>
new SqmMapJoin<>( new SqmMapJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getNavigablePath(), getNavigablePath(),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -74,11 +74,6 @@ public class SqmMapJoin<O, K, V>
return path; return path;
} }
@Override
public MapPersistentAttribute<O, K, V> getReferencedPathSource() {
return(MapPersistentAttribute<O, K, V>) super.getReferencedPathSource();
}
@Override @Override
public MapPersistentAttribute<O, K, V> getModel() { public MapPersistentAttribute<O, K, V> getModel() {
return (MapPersistentAttribute<O, K, V>) super.getModel(); return (MapPersistentAttribute<O, K, V>) super.getModel();
@ -91,23 +86,21 @@ public class SqmMapJoin<O, K, V>
@Override @Override
public MapPersistentAttribute<O, K, V> getAttribute() { public MapPersistentAttribute<O, K, V> getAttribute() {
//noinspection unchecked return getModel();
return (MapPersistentAttribute<O, K, V>) super.getAttribute();
} }
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
// JPA // JPA
@Override @Override
public SqmPath<K> key() { public SqmPath<K> key() {
final SqmPathSource<K> keyPathSource = getReferencedPathSource().getKeyPathSource(); final SqmPathSource<K> keyPathSource = getAttribute().getKeyPathSource();
return resolvePath( keyPathSource.getPathName(), keyPathSource ); return resolvePath( keyPathSource.getPathName(), keyPathSource );
} }
@Override @Override
public Path<V> value() { public Path<V> value() {
final SqmPathSource<V> elementPathSource = getReferencedPathSource().getElementPathSource(); final SqmPathSource<V> elementPathSource = getAttribute().getElementPathSource();
return resolvePath( elementPathSource.getPathName(), elementPathSource ); return resolvePath( elementPathSource.getPathName(), elementPathSource );
} }
@ -169,7 +162,7 @@ public class SqmMapJoin<O, K, V>
public SqmMapJoin<O, K, V> makeCopy(SqmCreationProcessingState creationProcessingState) { public SqmMapJoin<O, K, V> makeCopy(SqmCreationProcessingState creationProcessingState) {
return new SqmMapJoin<>( return new SqmMapJoin<>(
creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ), creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),

View File

@ -63,7 +63,7 @@ public class SqmSetJoin<O, E>
new SqmSetJoin<>( new SqmSetJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getNavigablePath(), getNavigablePath(),
getReferencedPathSource(), getModel(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -74,14 +74,9 @@ public class SqmSetJoin<O, E>
return path; return path;
} }
@Override
public SetPersistentAttribute<O,E> getReferencedPathSource() {
return (SetPersistentAttribute<O, E>) super.getReferencedPathSource();
}
@Override @Override
public SetPersistentAttribute<O, E> getModel() { public SetPersistentAttribute<O, E> getModel() {
return getReferencedPathSource(); return (SetPersistentAttribute<O, E>) super.getNodeType();
} }
@Override @Override
@ -91,7 +86,7 @@ public class SqmSetJoin<O, E>
@Override @Override
public SetPersistentAttribute<O, E> getAttribute() { public SetPersistentAttribute<O, E> getAttribute() {
return getReferencedPathSource(); return getModel();
} }
@Override @Override
@ -153,7 +148,7 @@ public class SqmSetJoin<O, E>
public SqmAttributeJoin<O, E> makeCopy(SqmCreationProcessingState creationProcessingState) { public SqmAttributeJoin<O, E> makeCopy(SqmCreationProcessingState creationProcessingState) {
return new SqmSetJoin<>( return new SqmSetJoin<>(
creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ), creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getModel(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),

View File

@ -11,6 +11,7 @@ import java.util.Locale;
import org.hibernate.metamodel.model.domain.EntityDomainType; import org.hibernate.metamodel.model.domain.EntityDomainType;
import org.hibernate.metamodel.model.domain.SingularPersistentAttribute; import org.hibernate.metamodel.model.domain.SingularPersistentAttribute;
import org.hibernate.query.sqm.SemanticQueryWalker; import org.hibernate.query.sqm.SemanticQueryWalker;
import org.hibernate.query.sqm.SqmPathSource;
import org.hibernate.spi.NavigablePath; import org.hibernate.spi.NavigablePath;
import org.hibernate.query.hql.spi.SqmCreationProcessingState; import org.hibernate.query.hql.spi.SqmCreationProcessingState;
import org.hibernate.query.sqm.NodeBuilder; import org.hibernate.query.sqm.NodeBuilder;
@ -71,7 +72,7 @@ public class SqmSingularJoin<O,T> extends AbstractSqmAttributeJoin<O,T> {
new SqmSingularJoin<>( new SqmSingularJoin<>(
getLhs().copy( context ), getLhs().copy( context ),
getNavigablePath(), getNavigablePath(),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),
@ -82,20 +83,14 @@ public class SqmSingularJoin<O,T> extends AbstractSqmAttributeJoin<O,T> {
return path; return path;
} }
@Override
public SingularPersistentAttribute<O, T> getReferencedPathSource() {
return (SingularPersistentAttribute<O, T>) super.getReferencedPathSource();
}
@Override @Override
public SingularPersistentAttribute<O, T> getModel() { public SingularPersistentAttribute<O, T> getModel() {
return getReferencedPathSource(); return (SingularPersistentAttribute<O, T>) super.getNodeType();
} }
@Override @Override
public SingularPersistentAttribute<O, T> getAttribute() { public SingularPersistentAttribute<O, T> getAttribute() {
//noinspection unchecked return getModel();
return (SingularPersistentAttribute<O, T>) super.getAttribute();
} }
@Override @Override
@ -141,7 +136,7 @@ public class SqmSingularJoin<O,T> extends AbstractSqmAttributeJoin<O,T> {
public SqmAttributeJoin<O, T> makeCopy(SqmCreationProcessingState creationProcessingState) { public SqmAttributeJoin<O, T> makeCopy(SqmCreationProcessingState creationProcessingState) {
return new SqmSingularJoin<>( return new SqmSingularJoin<>(
creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ), creationProcessingState.getPathRegistry().findFromByPath( getLhs().getNavigablePath() ),
getReferencedPathSource(), getAttribute(),
getExplicitAlias(), getExplicitAlias(),
getSqmJoinType(), getSqmJoinType(),
isFetched(), isFetched(),

View File

@ -75,6 +75,11 @@ public class SqmTreatedBagJoin<O,T, S extends T> extends SqmBagJoin<O,S> impleme
return treatTarget; return treatTarget;
} }
@Override
public EntityDomainType<S> getReferencedPathSource() {
return treatTarget;
}
@Override @Override
public SqmAttributeJoin<O, S> makeCopy(SqmCreationProcessingState creationProcessingState) { public SqmAttributeJoin<O, S> makeCopy(SqmCreationProcessingState creationProcessingState) {
return new SqmTreatedBagJoin<>( wrappedPath, treatTarget, getAlias() ); return new SqmTreatedBagJoin<>( wrappedPath, treatTarget, getAlias() );

View File

@ -72,8 +72,7 @@ public class SqmTreatedEntityJoin<T, S extends T> extends SqmEntityJoin<S> imple
@Override @Override
public EntityDomainType<S> getReferencedPathSource() { public EntityDomainType<S> getReferencedPathSource() {
//noinspection unchecked return treatTarget;
return (EntityDomainType<S>) wrappedPath.getReferencedPathSource();
} }
@Override @Override

View File

@ -67,11 +67,6 @@ public class SqmTreatedListJoin<O,T, S extends T> extends SqmListJoin<O,S> imple
return wrappedPath; return wrappedPath;
} }
@Override
public ListPersistentAttribute<O, S> getModel() {
return super.getModel();
}
@Override @Override
public EntityDomainType<S> getTreatTarget() { public EntityDomainType<S> getTreatTarget() {
return treatTarget; return treatTarget;
@ -82,6 +77,11 @@ public class SqmTreatedListJoin<O,T, S extends T> extends SqmListJoin<O,S> imple
return treatTarget; return treatTarget;
} }
@Override
public EntityDomainType<S> getReferencedPathSource() {
return treatTarget;
}
@Override @Override
public SqmPath<?> resolveIndexedAccess( public SqmPath<?> resolveIndexedAccess(
SqmExpression<?> selector, SqmExpression<?> selector,

View File

@ -73,6 +73,11 @@ public class SqmTreatedMapJoin<O, K, V, S extends V> extends SqmMapJoin<O, K, S>
return treatTarget; return treatTarget;
} }
@Override
public EntityDomainType<S> getReferencedPathSource() {
return treatTarget;
}
@Override @Override
public SqmMapJoin<O, K, S> makeCopy(SqmCreationProcessingState creationProcessingState) { public SqmMapJoin<O, K, S> makeCopy(SqmCreationProcessingState creationProcessingState) {
return new SqmTreatedMapJoin<>( return new SqmTreatedMapJoin<>(

View File

@ -65,11 +65,6 @@ public class SqmTreatedSetJoin<O,T, S extends T> extends SqmSetJoin<O,S> impleme
return wrappedPath; return wrappedPath;
} }
@Override
public SetPersistentAttribute<O,S> getModel() {
return super.getModel();
}
@Override @Override
public EntityDomainType<S> getTreatTarget() { public EntityDomainType<S> getTreatTarget() {
return treatTarget; return treatTarget;
@ -81,8 +76,8 @@ public class SqmTreatedSetJoin<O,T, S extends T> extends SqmSetJoin<O,S> impleme
} }
@Override @Override
public SetPersistentAttribute<O,S> getReferencedPathSource() { public EntityDomainType<S> getReferencedPathSource() {
return super.getReferencedPathSource(); return treatTarget;
} }
@Override @Override

View File

@ -75,6 +75,11 @@ public class SqmTreatedSingularJoin<O,T, S extends T> extends SqmSingularJoin<O,
return treatTarget; return treatTarget;
} }
@Override
public EntityDomainType<S> getReferencedPathSource() {
return getTreatTarget();
}
@Override @Override
public SqmAttributeJoin<O, S> makeCopy(SqmCreationProcessingState creationProcessingState) { public SqmAttributeJoin<O, S> makeCopy(SqmCreationProcessingState creationProcessingState) {
return new SqmTreatedSingularJoin<>( wrappedPath, treatTarget, getAlias() ); return new SqmTreatedSingularJoin<>( wrappedPath, treatTarget, getAlias() );