HHH-17615 Small fix to entity joins with soft-delete and inheritance

This commit is contained in:
Marco Belladelli 2024-01-09 11:26:36 +01:00 committed by Christian Beikov
parent 91d22f1a09
commit fccce5561d
1 changed files with 5 additions and 7 deletions

View File

@ -12,7 +12,6 @@ import jakarta.persistence.metamodel.Type;
import org.hibernate.HibernateException;
import org.hibernate.Internal;
import org.hibernate.LockMode;
import org.hibernate.boot.model.internal.SoftDeleteHelper;
import org.hibernate.boot.model.process.internal.InferredBasicValueResolver;
import org.hibernate.dialect.Dialect;
import org.hibernate.dialect.function.TimestampaddFunction;
@ -29,7 +28,6 @@ import org.hibernate.id.BulkInsertionCapableIdentifierGenerator;
import org.hibernate.id.CompositeNestedGeneratedValueGenerator;
import org.hibernate.id.OptimizableGenerator;
import org.hibernate.id.enhanced.Optimizer;
import org.hibernate.internal.util.MutableBoolean;
import org.hibernate.internal.util.collections.CollectionHelper;
import org.hibernate.internal.util.collections.Stack;
import org.hibernate.internal.util.collections.StandardStack;
@ -426,6 +424,7 @@ import java.util.function.Function;
import java.util.function.Supplier;
import static java.util.Collections.singletonList;
import static org.hibernate.boot.model.internal.SoftDeleteHelper.createNonSoftDeletedRestriction;
import static org.hibernate.generator.EventType.INSERT;
import static org.hibernate.internal.util.NullnessHelper.coalesceSuppliedValues;
import static org.hibernate.query.sqm.BinaryArithmeticOperator.ADD;
@ -3457,7 +3456,6 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
}
private TableGroup consumeEntityJoin(SqmEntityJoin<?> sqmJoin, TableGroup lhsTableGroup, boolean transitive) {
final MutableBoolean needsTreat = new MutableBoolean( false );
final EntityPersister entityDescriptor = resolveEntityPersister( sqmJoin.getReferencedPathSource() );
final SqlAstJoinType correspondingSqlJoinType = sqmJoin.getSqmJoinType().getCorrespondingSqlJoinType();
@ -3466,12 +3464,12 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
sqmJoin.getNavigablePath(),
sqmJoin.getExplicitAlias(),
null,
() -> p -> needsTreat.setValue( true ),
() -> p -> {},
this
);
registerSqmFromTableGroup( sqmJoin, tableGroup );
if ( needsTreat.getValue() ) {
if ( entityDescriptor.isInherited() && !sqmJoin.hasTreats() ) {
// Register new treat to apply the discriminator condition to the table reference itself, see #pruneTableGroupJoins
registerEntityNameUsage( tableGroup, EntityNameUse.TREAT, entityDescriptor.getEntityName() );
}
@ -3495,8 +3493,8 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
final SoftDeleteMapping softDeleteMapping = entityDescriptor.getSoftDeleteMapping();
if ( softDeleteMapping != null ) {
final Predicate softDeleteRestriction = SoftDeleteHelper.createNonSoftDeletedRestriction(
tableGroup.resolveTableReference( entityDescriptor.getSoftDeleteTableDetails().getTableName() ),
final Predicate softDeleteRestriction = createNonSoftDeletedRestriction(
tableGroup.resolveTableReference( softDeleteMapping.getTableName() ),
softDeleteMapping
);
tableGroupJoin.applyPredicate( softDeleteRestriction );