HHH-11768 - Fix FK ConstraintViolationException with ordered inserts enabled and cascade persist.

This commit is contained in:
Chris Cranford 2017-06-09 10:40:43 -04:00
parent e7e6cc53ab
commit 234849d33b
1 changed files with 7 additions and 3 deletions
hibernate-core/src/main/java/org/hibernate/engine/spi

View File

@ -1104,7 +1104,7 @@ public class ActionQueue {
//Make sure that child entries are not before parents //Make sure that child entries are not before parents
for ( int j = i - 1; j >= 0; j-- ) { for ( int j = i - 1; j >= 0; j-- ) {
BatchIdentifier prevBatchIdentifier = latestBatches.get( j ); BatchIdentifier prevBatchIdentifier = latestBatches.get( j );
if(prevBatchIdentifier.getParentEntityNames().contains( entityName )) { if ( prevBatchIdentifier.getParentEntityNames().contains( entityName ) ) {
latestBatches.remove( batchIdentifier ); latestBatches.remove( batchIdentifier );
latestBatches.add( j, batchIdentifier ); latestBatches.add( j, batchIdentifier );
} }
@ -1114,8 +1114,12 @@ public class ActionQueue {
for ( int j = i + 1; j < latestBatches.size(); j++ ) { for ( int j = i + 1; j < latestBatches.size(); j++ ) {
BatchIdentifier nextBatchIdentifier = latestBatches.get( j ); BatchIdentifier nextBatchIdentifier = latestBatches.get( j );
//Take care of unidirectional @OneToOne associations but exclude bidirectional @ManyToMany //Take care of unidirectional @OneToOne associations but exclude bidirectional @ManyToMany
if(nextBatchIdentifier.getChildEntityNames().contains( entityName ) && if ( nextBatchIdentifier.getChildEntityNames().contains( entityName ) &&
!batchIdentifier.getChildEntityNames().contains( nextBatchIdentifier.getEntityName() )) { !batchIdentifier.getChildEntityNames().contains( nextBatchIdentifier.getEntityName() ) ) {
latestBatches.remove( batchIdentifier );
latestBatches.add( j, batchIdentifier );
}
else if ( batchIdentifier.getParentEntityNames().contains( nextBatchIdentifier.getEntityName() ) ) {
latestBatches.remove( batchIdentifier ); latestBatches.remove( batchIdentifier );
latestBatches.add( j, batchIdentifier ); latestBatches.add( j, batchIdentifier );
} }