HHH-16811 Dirty property lost and not detected with Batch Fetch, Embedded and FetchMode SELECT

This commit is contained in:
Andrea Boriero 2023-06-27 13:59:18 +02:00 committed by Andrea Boriero
parent ac9a5fc42c
commit dac288d1bb
2 changed files with 22 additions and 8 deletions

View File

@ -186,8 +186,8 @@ public abstract class AbstractEmbeddableInitializer extends AbstractFetchParentA
case NULL:
return;
case INITIAL:
if ( isParentInstanceNull() ) {
state = State.NULL;
state = determinInitialState();
if ( state != State.INITIAL ) {
return;
}
@ -269,9 +269,24 @@ public abstract class AbstractEmbeddableInitializer extends AbstractFetchParentA
);
}
private boolean isParentInstanceNull() {
private State determinInitialState(){
final EntityInitializer entityInitializer = getOwningEntityInitializer();
if ( entityInitializer != null ) {
if ( entityInitializer.getParentKey() == null ) {
// parent instance is null;
return State.NULL;
}
else if ( entityInitializer.isEntityInitialized() ) {
// parent instance has been initialized, we do not need to inject the state
return State.INJECTED;
}
}
return State.INITIAL;
}
private EntityInitializer getOwningEntityInitializer() {
if ( isPartOfKey ) {
return false;
return null;
}
FetchParentAccess parentAccess = fetchParentAccess;
@ -280,13 +295,11 @@ public abstract class AbstractEmbeddableInitializer extends AbstractFetchParentA
: "isPartOfKey should have been true in this case";
parentAccess = parentAccess.getFetchParentAccess();
}
if ( parentAccess == null ) {
return false;
return null;
}
final EntityInitializer entityInitializer = parentAccess.asEntityInitializer();
return entityInitializer != null && entityInitializer.getParentKey() == null;
return entityInitializer;
}
private void extractRowState(RowProcessingState processingState) {

View File

@ -75,6 +75,7 @@ public abstract class AbstractBatchEntitySelectFetchInitializer extends Abstract
RowProcessingState rowProcessingState,
ToOneAttributeMapping referencedModelPart,
FetchParentAccess parentAccess) {
if ( state != State.UNINITIALIZED ) {
return;
}