HHH-13201 - do not set empty text on collection join parent without queryable collection
This commit is contained in:
parent
ea24abd757
commit
19af434b21
|
@ -368,7 +368,9 @@ public class FromElementFactory implements SqlTokenTypes {
|
||||||
// origin.addDestination( destination );
|
// origin.addDestination( destination );
|
||||||
// This was the cause of HHH-242
|
// This was the cause of HHH-242
|
||||||
// origin.setType( FROM_FRAGMENT ); // Set the parent node type so that the AST is properly formed.
|
// origin.setType( FROM_FRAGMENT ); // Set the parent node type so that the AST is properly formed.
|
||||||
origin.setText( "" ); // The destination node will have all the FROM text.
|
if ( origin.getQueryableCollection() != null ) {
|
||||||
|
origin.setText( "" ); // The destination node will have all the FROM text.
|
||||||
|
}
|
||||||
origin.setCollectionJoin( true ); // The parent node is a collection join too (voodoo - see JoinProcessor)
|
origin.setCollectionJoin( true ); // The parent node is a collection join too (voodoo - see JoinProcessor)
|
||||||
fromClause.addCollectionJoinFromElementByPath( path, destination );
|
fromClause.addCollectionJoinFromElementByPath( path, destination );
|
||||||
fromClause.getWalker().addQuerySpaces( queryableCollection.getCollectionSpaces() );
|
fromClause.getWalker().addQuerySpaces( queryableCollection.getCollectionSpaces() );
|
||||||
|
|
|
@ -193,7 +193,7 @@ public class SelectClause extends SelectExpressionList {
|
||||||
FromElement fromElement = (FromElement) iterator.next();
|
FromElement fromElement = (FromElement) iterator.next();
|
||||||
|
|
||||||
if ( fromElement.isFetch() ) {
|
if ( fromElement.isFetch() ) {
|
||||||
FromElement origin = null;
|
FromElement origin;
|
||||||
if ( fromElement.getRealOrigin() == null ) {
|
if ( fromElement.getRealOrigin() == null ) {
|
||||||
// work around that crazy issue where the tree contains
|
// work around that crazy issue where the tree contains
|
||||||
// "empty" FromElements (no text); afaict, this is caused
|
// "empty" FromElements (no text); afaict, this is caused
|
||||||
|
|
|
@ -0,0 +1,71 @@
|
||||||
|
package org.hibernate.test.hql;
|
||||||
|
|
||||||
|
import org.hibernate.jpa.test.BaseEntityManagerFunctionalTestCase;
|
||||||
|
import org.hibernate.testing.TestForIssue;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import javax.persistence.*;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static javax.persistence.CascadeType.ALL;
|
||||||
|
import static org.hibernate.testing.transaction.TransactionUtil.doInJPA;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Moritz Becker (moritz.becker@ordami.com)
|
||||||
|
* @date 12/01/2019
|
||||||
|
* @company ordami GmbH
|
||||||
|
*/
|
||||||
|
@TestForIssue(jiraKey = "HHH-13201")
|
||||||
|
public class FetchNonRootRelativeElementCollectionAndAssociationTest extends BaseEntityManagerFunctionalTestCase {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Class<?>[] getAnnotatedClasses() {
|
||||||
|
return new Class<?>[] { ProductNaturalId.class, Product.class, ProductDetail.class };
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testJoinedSubclassUpdateWithCorrelation() {
|
||||||
|
doInJPA( this::entityManagerFactory, entityManager -> {
|
||||||
|
// DO NOT CHANGE this query: it used to trigger an error caused
|
||||||
|
// by the origin FromElement for the association fetch being resolved to the wrong FromElement due to the
|
||||||
|
// presence of an element collection join.
|
||||||
|
String u = "select prod from ProductNaturalId nat inner join nat.product prod " +
|
||||||
|
"left join fetch prod.productDetail " +
|
||||||
|
"left join fetch prod.normalizedPricesByUnit";
|
||||||
|
Query query = entityManager.createQuery( u, Product.class );
|
||||||
|
query.getResultList();
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity(name = "ProductNaturalId")
|
||||||
|
public class ProductNaturalId {
|
||||||
|
@Id
|
||||||
|
private String naturalId;
|
||||||
|
@OneToOne(optional = false)
|
||||||
|
private Product product;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity(name = "Product")
|
||||||
|
public class Product {
|
||||||
|
@Id
|
||||||
|
private Long id;
|
||||||
|
@OneToOne(mappedBy = "product", cascade = ALL, fetch = FetchType.LAZY)
|
||||||
|
private ProductDetail productDetail;
|
||||||
|
@OneToOne(mappedBy = "product", cascade = ALL, fetch = FetchType.LAZY)
|
||||||
|
private ProductNaturalId naturalId;
|
||||||
|
@ElementCollection(fetch = FetchType.LAZY)
|
||||||
|
private Map<String, String> normalizedPricesByUnit = new HashMap<>();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity(name = "ProductDetail")
|
||||||
|
public class ProductDetail {
|
||||||
|
@Id
|
||||||
|
private Long id;
|
||||||
|
@OneToOne(optional = false)
|
||||||
|
@JoinColumn(name = "id")
|
||||||
|
@MapsId
|
||||||
|
private Product product;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue