HHH-17445 Don't force initialization of correlated joined table group
This commit is contained in:
parent
e369015b4d
commit
ac3b5281c3
|
@ -3741,8 +3741,6 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
|
||||||
querySpec::applyPredicate,
|
querySpec::applyPredicate,
|
||||||
this
|
this
|
||||||
);
|
);
|
||||||
// Force initialization of a possible lazy table group
|
|
||||||
tableGroup.getPrimaryTableReference();
|
|
||||||
querySpec.getFromClause().addRoot( tableGroup );
|
querySpec.getFromClause().addRoot( tableGroup );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
|
@ -18,7 +18,6 @@ import org.assertj.core.api.Assertions;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
@JiraKey("HHH-16721")
|
|
||||||
@DomainModel(annotatedClasses = {
|
@DomainModel(annotatedClasses = {
|
||||||
ImplicitJoinInSubqueryTest.A.class,
|
ImplicitJoinInSubqueryTest.A.class,
|
||||||
ImplicitJoinInSubqueryTest.B.class,
|
ImplicitJoinInSubqueryTest.B.class,
|
||||||
|
@ -28,6 +27,7 @@ import static org.assertj.core.api.Assertions.assertThat;
|
||||||
public class ImplicitJoinInSubqueryTest {
|
public class ImplicitJoinInSubqueryTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@JiraKey("HHH-16721")
|
||||||
public void testImplicitJoinInSubquery(SessionFactoryScope scope) {
|
public void testImplicitJoinInSubquery(SessionFactoryScope scope) {
|
||||||
SQLStatementInspector statementInspector = scope.getCollectingStatementInspector();
|
SQLStatementInspector statementInspector = scope.getCollectingStatementInspector();
|
||||||
statementInspector.clear();
|
statementInspector.clear();
|
||||||
|
@ -41,6 +41,22 @@ public class ImplicitJoinInSubqueryTest {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@JiraKey("HHH-17445")
|
||||||
|
public void testImplicitJoinInSubquery2(SessionFactoryScope scope) {
|
||||||
|
SQLStatementInspector statementInspector = scope.getCollectingStatementInspector();
|
||||||
|
statementInspector.clear();
|
||||||
|
scope.inTransaction(
|
||||||
|
entityManager -> {
|
||||||
|
entityManager.createSelectionQuery(
|
||||||
|
"select a from A a where exists (select 1 from B b where a.b.c is null)"
|
||||||
|
).getResultList();
|
||||||
|
assertThat( statementInspector.getSqlQueries().get( 0 ) ).contains( "b1_0.c_id is null" );
|
||||||
|
assertThat( statementInspector.getSqlQueries().get( 0 ) ).doesNotContain( ".id=b1_0.c_id" );
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
@Entity(name = "A")
|
@Entity(name = "A")
|
||||||
public static class A {
|
public static class A {
|
||||||
@Id
|
@Id
|
||||||
|
|
Loading…
Reference in New Issue