fix for HHH-16263
use a LinkedHashSet so that things are more deterministic this is perhaps not a "complete" fix, but it will have to do for now
This commit is contained in:
parent
529f8e6fbe
commit
15ad2c3d98
|
@ -13,8 +13,8 @@ import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
import java.util.LinkedHashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
@ -49,7 +49,6 @@ import org.hibernate.mapping.Collection;
|
||||||
import org.hibernate.mapping.Column;
|
import org.hibernate.mapping.Column;
|
||||||
import org.hibernate.mapping.Component;
|
import org.hibernate.mapping.Component;
|
||||||
import org.hibernate.mapping.Join;
|
import org.hibernate.mapping.Join;
|
||||||
import org.hibernate.mapping.JoinedSubclass;
|
|
||||||
import org.hibernate.mapping.MappedSuperclass;
|
import org.hibernate.mapping.MappedSuperclass;
|
||||||
import org.hibernate.mapping.PersistentClass;
|
import org.hibernate.mapping.PersistentClass;
|
||||||
import org.hibernate.mapping.Property;
|
import org.hibernate.mapping.Property;
|
||||||
|
@ -437,7 +436,7 @@ public class BinderHelper {
|
||||||
final String name = collector.getPhysicalColumnName( referencedTable, joinColumn.getReferencedColumn() );
|
final String name = collector.getPhysicalColumnName( referencedTable, joinColumn.getReferencedColumn() );
|
||||||
final Column column = new Column( name );
|
final Column column = new Column( name );
|
||||||
orderedColumns.add( column );
|
orderedColumns.add( column );
|
||||||
columnsToProperty.put( column, new HashSet<>() );
|
columnsToProperty.put( column, new LinkedHashSet<>() ); //need to use a LinkedHashSet here to make it deterministic
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now, for each column find the properties of the target entity
|
// Now, for each column find the properties of the target entity
|
||||||
|
@ -520,7 +519,6 @@ public class BinderHelper {
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// we have the first column of a new property
|
// we have the first column of a new property
|
||||||
orderedProperties.add( property );
|
|
||||||
if ( property.getColumnSpan() > 1 ) {
|
if ( property.getColumnSpan() > 1 ) {
|
||||||
if ( !property.getColumns().get(0).equals( column ) ) {
|
if ( !property.getColumns().get(0).equals( column ) ) {
|
||||||
// the columns have to occur in the right order in the property
|
// the columns have to occur in the right order in the property
|
||||||
|
@ -531,6 +529,7 @@ public class BinderHelper {
|
||||||
currentProperty = property;
|
currentProperty = property;
|
||||||
lastPropertyColumnIndex = 1;
|
lastPropertyColumnIndex = 1;
|
||||||
}
|
}
|
||||||
|
orderedProperties.add( property );
|
||||||
}
|
}
|
||||||
break; // we're only considering the first matching property for now
|
break; // we're only considering the first matching property for now
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,202 @@
|
||||||
|
package org.hibernate.orm.test.cuk;//package com.example.demo;
|
||||||
|
|
||||||
|
import jakarta.persistence.*;
|
||||||
|
import org.hibernate.annotations.DynamicUpdate;
|
||||||
|
import org.hibernate.annotations.NotFound;
|
||||||
|
import org.hibernate.annotations.NotFoundAction;
|
||||||
|
import org.hibernate.testing.orm.junit.DomainModel;
|
||||||
|
import org.hibernate.testing.orm.junit.JiraKey;
|
||||||
|
import org.hibernate.testing.orm.junit.SessionFactory;
|
||||||
|
import org.hibernate.testing.orm.junit.SessionFactoryScope;
|
||||||
|
import org.junit.jupiter.api.AfterAll;
|
||||||
|
import org.junit.jupiter.api.BeforeAll;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@SessionFactory
|
||||||
|
@DomainModel(annotatedClasses = {
|
||||||
|
JoinColumnOccursOutOfOrderTest.MasterEntity.class,
|
||||||
|
JoinColumnOccursOutOfOrderTest.ChildTwoEntity.class,
|
||||||
|
JoinColumnOccursOutOfOrderTest.ChildEntityOne.class,
|
||||||
|
JoinColumnOccursOutOfOrderTest.ChildEntityFour.class,
|
||||||
|
JoinColumnOccursOutOfOrderTest.ChildEntityThree.class,
|
||||||
|
})
|
||||||
|
@JiraKey("HHH-16263")
|
||||||
|
public class JoinColumnOccursOutOfOrderTest {
|
||||||
|
|
||||||
|
@BeforeAll
|
||||||
|
public void setUp(SessionFactoryScope scope) {
|
||||||
|
scope.inTransaction( session -> {
|
||||||
|
var meta = new MasterEntity();
|
||||||
|
meta.setId(1l);
|
||||||
|
meta.column1 = "1";
|
||||||
|
meta.column2 = "2";
|
||||||
|
meta.column3 = "3";
|
||||||
|
session.persist( meta );
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
|
||||||
|
@AfterAll
|
||||||
|
public void tearDown(SessionFactoryScope scope) {
|
||||||
|
scope.inTransaction( session -> {
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testOutOffOrder(SessionFactoryScope scope) {
|
||||||
|
scope.inTransaction( session -> {
|
||||||
|
final var container = session.createQuery(
|
||||||
|
"from MasterEntity container where container.id = :param ",
|
||||||
|
MasterEntity.class
|
||||||
|
).setParameter("param", 1).getSingleResult();
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Embeddable
|
||||||
|
public static class ChildOneId implements Serializable {
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_1", nullable = false, length = 7)
|
||||||
|
private String column1;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_2", nullable = false, length = 4)
|
||||||
|
private String column2;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_3", nullable = false, length = 2)
|
||||||
|
private String column3;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Embeddable
|
||||||
|
public static class ChildTwoId implements Serializable {
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_1", length = 7, nullable = false)
|
||||||
|
private String column1;
|
||||||
|
@Column(name = "COLUMN_2", length = 4, nullable = false)
|
||||||
|
private String column2;
|
||||||
|
@Column(name = "COLUMN_3", length = 2, nullable = false)
|
||||||
|
private String column3;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Embeddable
|
||||||
|
public static class ChildThreeId implements Serializable {
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_1", nullable = false, length = 7)
|
||||||
|
private String column1;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_2", nullable = false, length = 4)
|
||||||
|
private String column2;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_3", nullable = false, length = 2)
|
||||||
|
private String column3;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_4", nullable = false)
|
||||||
|
private LocalDateTime creation;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Embeddable
|
||||||
|
public static class ChildFourId implements Serializable {
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_1", length = 7, nullable = false)
|
||||||
|
private String column1;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_2", length = 4, nullable = false)
|
||||||
|
private String colum2;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_3", length = 2, nullable = false)
|
||||||
|
private String column3;
|
||||||
|
|
||||||
|
@Column(name = "NON_UNIQUE_ID", nullable = false)
|
||||||
|
private Long nonUNiqueId;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_4", nullable = false)
|
||||||
|
private LocalDateTime creation;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
public static class ChildEntityFour {
|
||||||
|
@EmbeddedId
|
||||||
|
private ChildFourId id;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
public static class ChildEntityOne {
|
||||||
|
@EmbeddedId
|
||||||
|
private ChildOneId id;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@DynamicUpdate
|
||||||
|
public static class ChildTwoEntity {
|
||||||
|
@EmbeddedId
|
||||||
|
private ChildTwoId id;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
public static class ChildEntityThree {
|
||||||
|
@EmbeddedId
|
||||||
|
private ChildThreeId id;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Entity(name = "MasterEntity")
|
||||||
|
public static class MasterEntity {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
@Column(name = "ID", unique = true, nullable = false)
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_1", nullable = false, length = 7)
|
||||||
|
private String column1;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_2", nullable = false, length = 4)
|
||||||
|
private String column2;
|
||||||
|
|
||||||
|
@Column(name = "COLUMN_3", nullable = false, length = 2)
|
||||||
|
private String column3;
|
||||||
|
|
||||||
|
@OneToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL, orphanRemoval = true)
|
||||||
|
@JoinColumns(foreignKey = @ForeignKey(ConstraintMode.NO_CONSTRAINT), value = {
|
||||||
|
@JoinColumn(name = "COLUMN_1", referencedColumnName = "COLUMN_1", insertable = false, updatable = false),
|
||||||
|
@JoinColumn(name = "COLUMN_2", referencedColumnName = "COLUMN_2", insertable = false, updatable = false),
|
||||||
|
@JoinColumn(name = "COLUMN_3", referencedColumnName = "COLUMN_3", insertable = false, updatable = false)
|
||||||
|
})
|
||||||
|
@NotFound(action = NotFoundAction.IGNORE)
|
||||||
|
private ChildEntityOne childEntityOne;
|
||||||
|
|
||||||
|
@OneToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL, orphanRemoval = true)
|
||||||
|
@JoinColumns(foreignKey = @ForeignKey(ConstraintMode.NO_CONSTRAINT), value = {
|
||||||
|
@JoinColumn(name = "COLUMN_1", referencedColumnName = "COLUMN_1", insertable = false, updatable = false),
|
||||||
|
@JoinColumn(name = "COLUMN_2", referencedColumnName = "COLUMN_2", insertable = false, updatable = false),
|
||||||
|
@JoinColumn(name = "COLUMN_3", referencedColumnName = "COLUMN_3", insertable = false, updatable = false)
|
||||||
|
})
|
||||||
|
@NotFound(action = NotFoundAction.IGNORE)
|
||||||
|
private ChildTwoEntity childEntityTwo;
|
||||||
|
|
||||||
|
@OneToMany(fetch = FetchType.LAZY)
|
||||||
|
@JoinColumn(name = "COLUMN_1", referencedColumnName = "COLUMN_1", insertable = false, updatable = false)
|
||||||
|
@JoinColumn(name = "COLUMN_2", referencedColumnName = "COLUMN_2", insertable = false, updatable = false)
|
||||||
|
@JoinColumn(name = "COLUMN_3", referencedColumnName = "COLUMN_3", insertable = false, updatable = false)
|
||||||
|
private List<ChildEntityThree> childEntityThree;
|
||||||
|
|
||||||
|
@OneToMany(fetch = FetchType.LAZY)
|
||||||
|
@JoinColumn(name = "COLUMN_1", referencedColumnName = "COLUMN_1", insertable = false, updatable = false)
|
||||||
|
@JoinColumn(name = "COLUMN_2", referencedColumnName = "COLUMN_2", insertable = false, updatable = false)
|
||||||
|
@JoinColumn(name = "COLUMN_3", referencedColumnName = "COLUMN_3", insertable = false, updatable = false)
|
||||||
|
private List<ChildEntityFour> childEntityFour;
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(Long id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue