HHH-14305 Memory optimisations for AbstractEntityPersister#uniqueKeyLoaders
This commit is contained in:
parent
9f54dae5d2
commit
ad5bec0a54
|
@ -250,12 +250,12 @@ public abstract class AbstractEntityPersister
|
||||||
|
|
||||||
private volatile Set<String> affectingFetchProfileNames;
|
private volatile Set<String> affectingFetchProfileNames;
|
||||||
|
|
||||||
private final Map uniqueKeyLoaders = new HashMap();
|
|
||||||
|
|
||||||
private final LockModeEnumMap<LockingStrategy> lockers = new LockModeEnumMap<>();
|
private final LockModeEnumMap<LockingStrategy> lockers = new LockModeEnumMap<>();
|
||||||
|
|
||||||
private final EntityLoaderLazyCollection loaders = new EntityLoaderLazyCollection();
|
private final EntityLoaderLazyCollection loaders = new EntityLoaderLazyCollection();
|
||||||
|
|
||||||
|
private volatile Map<String,EntityLoader> uniqueKeyLoaders;
|
||||||
|
|
||||||
// SQL strings
|
// SQL strings
|
||||||
private String sqlVersionSelectString;
|
private String sqlVersionSelectString;
|
||||||
private String sqlSnapshotSelectString;
|
private String sqlSnapshotSelectString;
|
||||||
|
@ -2433,7 +2433,8 @@ public abstract class AbstractEntityPersister
|
||||||
&& propertyName.indexOf( '.' ) < 0; //ugly little workaround for fact that createUniqueKeyLoaders() does not handle component properties
|
&& propertyName.indexOf( '.' ) < 0; //ugly little workaround for fact that createUniqueKeyLoaders() does not handle component properties
|
||||||
|
|
||||||
if ( useStaticLoader ) {
|
if ( useStaticLoader ) {
|
||||||
return (EntityLoader) uniqueKeyLoaders.get( propertyName );
|
final Map<String, EntityLoader> uniqueKeyLoaders = this.uniqueKeyLoaders;
|
||||||
|
return uniqueKeyLoaders == null ? null : uniqueKeyLoaders.get( propertyName );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return createUniqueKeyLoader(
|
return createUniqueKeyLoader(
|
||||||
|
@ -2453,6 +2454,9 @@ public abstract class AbstractEntityPersister
|
||||||
String[] propertyNames = getPropertyNames();
|
String[] propertyNames = getPropertyNames();
|
||||||
for ( int i = 0; i < entityMetamodel.getPropertySpan(); i++ ) {
|
for ( int i = 0; i < entityMetamodel.getPropertySpan(); i++ ) {
|
||||||
if ( propertyUniqueness[i] ) {
|
if ( propertyUniqueness[i] ) {
|
||||||
|
if ( uniqueKeyLoaders == null ) {
|
||||||
|
this.uniqueKeyLoaders = new HashMap<>();
|
||||||
|
}
|
||||||
//don't need filters for the static loaders
|
//don't need filters for the static loaders
|
||||||
uniqueKeyLoaders.put(
|
uniqueKeyLoaders.put(
|
||||||
propertyNames[i],
|
propertyNames[i],
|
||||||
|
|
Loading…
Reference in New Issue