|
|
@ -85,7 +85,6 @@ import org.hibernate.boot.spi.InFlightMetadataCollector;
|
|
|
|
import org.hibernate.boot.spi.MetadataBuildingContext;
|
|
|
|
import org.hibernate.boot.spi.MetadataBuildingContext;
|
|
|
|
import org.hibernate.boot.spi.PropertyData;
|
|
|
|
import org.hibernate.boot.spi.PropertyData;
|
|
|
|
import org.hibernate.cfg.AvailableSettings;
|
|
|
|
import org.hibernate.cfg.AvailableSettings;
|
|
|
|
import org.hibernate.engine.OptimisticLockStyle;
|
|
|
|
|
|
|
|
import org.hibernate.engine.jdbc.env.spi.JdbcEnvironment;
|
|
|
|
import org.hibernate.engine.jdbc.env.spi.JdbcEnvironment;
|
|
|
|
import org.hibernate.engine.spi.FilterDefinition;
|
|
|
|
import org.hibernate.engine.spi.FilterDefinition;
|
|
|
|
import org.hibernate.internal.CoreMessageLogger;
|
|
|
|
import org.hibernate.internal.CoreMessageLogger;
|
|
|
@ -136,6 +135,8 @@ import jakarta.persistence.SharedCacheMode;
|
|
|
|
import jakarta.persistence.UniqueConstraint;
|
|
|
|
import jakarta.persistence.UniqueConstraint;
|
|
|
|
|
|
|
|
|
|
|
|
import static jakarta.persistence.InheritanceType.SINGLE_TABLE;
|
|
|
|
import static jakarta.persistence.InheritanceType.SINGLE_TABLE;
|
|
|
|
|
|
|
|
import static org.hibernate.annotations.PolymorphismType.EXPLICIT;
|
|
|
|
|
|
|
|
import static org.hibernate.annotations.PolymorphismType.IMPLICIT;
|
|
|
|
import static org.hibernate.boot.model.internal.AnnotatedClassType.MAPPED_SUPERCLASS;
|
|
|
|
import static org.hibernate.boot.model.internal.AnnotatedClassType.MAPPED_SUPERCLASS;
|
|
|
|
import static org.hibernate.boot.model.internal.AnnotatedDiscriminatorColumn.buildDiscriminatorColumn;
|
|
|
|
import static org.hibernate.boot.model.internal.AnnotatedDiscriminatorColumn.buildDiscriminatorColumn;
|
|
|
|
import static org.hibernate.boot.model.internal.AnnotatedJoinColumn.buildInheritanceJoinColumn;
|
|
|
|
import static org.hibernate.boot.model.internal.AnnotatedJoinColumn.buildInheritanceJoinColumn;
|
|
|
@ -155,7 +156,9 @@ import static org.hibernate.boot.model.internal.PropertyBinder.hasIdAnnotation;
|
|
|
|
import static org.hibernate.boot.model.internal.PropertyBinder.processElementAnnotations;
|
|
|
|
import static org.hibernate.boot.model.internal.PropertyBinder.processElementAnnotations;
|
|
|
|
import static org.hibernate.boot.model.internal.PropertyHolderBuilder.buildPropertyHolder;
|
|
|
|
import static org.hibernate.boot.model.internal.PropertyHolderBuilder.buildPropertyHolder;
|
|
|
|
import static org.hibernate.boot.model.internal.BinderHelper.extractFromPackage;
|
|
|
|
import static org.hibernate.boot.model.internal.BinderHelper.extractFromPackage;
|
|
|
|
|
|
|
|
import static org.hibernate.boot.model.internal.TableBinder.bindForeignKey;
|
|
|
|
import static org.hibernate.boot.model.naming.Identifier.toIdentifier;
|
|
|
|
import static org.hibernate.boot.model.naming.Identifier.toIdentifier;
|
|
|
|
|
|
|
|
import static org.hibernate.engine.OptimisticLockStyle.fromLockType;
|
|
|
|
import static org.hibernate.engine.spi.ExecuteUpdateResultCheckStyle.fromResultCheckStyle;
|
|
|
|
import static org.hibernate.engine.spi.ExecuteUpdateResultCheckStyle.fromResultCheckStyle;
|
|
|
|
import static org.hibernate.internal.util.StringHelper.isEmpty;
|
|
|
|
import static org.hibernate.internal.util.StringHelper.isEmpty;
|
|
|
|
import static org.hibernate.internal.util.StringHelper.isNotEmpty;
|
|
|
|
import static org.hibernate.internal.util.StringHelper.isNotEmpty;
|
|
|
@ -756,9 +759,8 @@ public class EntityBinder {
|
|
|
|
uniqueConstraints = new UniqueConstraint[0];
|
|
|
|
uniqueConstraints = new UniqueConstraint[0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
final InFlightMetadataCollector collector = context.getMetadataCollector();
|
|
|
|
|
|
|
|
if ( inheritanceState.hasTable() ) {
|
|
|
|
if ( inheritanceState.hasTable() ) {
|
|
|
|
createTable( inheritanceState, superEntity, schema, table, catalog, uniqueConstraints, collector );
|
|
|
|
createTable( inheritanceState, superEntity, schema, table, catalog, uniqueConstraints );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
else {
|
|
|
|
// must be a SINGLE_TABLE mapping for a subclass
|
|
|
|
// must be a SINGLE_TABLE mapping for a subclass
|
|
|
@ -772,7 +774,7 @@ public class EntityBinder {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// we at least need to properly set up the EntityTableXref
|
|
|
|
// we at least need to properly set up the EntityTableXref
|
|
|
|
bindTableForDiscriminatedSubclass( collector.getEntityTableXref( superEntity.getEntityName() ) );
|
|
|
|
bindTableForDiscriminatedSubclass( superEntity.getEntityName() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -782,8 +784,7 @@ public class EntityBinder {
|
|
|
|
String schema,
|
|
|
|
String schema,
|
|
|
|
String table,
|
|
|
|
String table,
|
|
|
|
String catalog,
|
|
|
|
String catalog,
|
|
|
|
UniqueConstraint[] uniqueConstraints,
|
|
|
|
UniqueConstraint[] uniqueConstraints) {
|
|
|
|
InFlightMetadataCollector collector) {
|
|
|
|
|
|
|
|
final RowId rowId = annotatedClass.getAnnotation( RowId.class );
|
|
|
|
final RowId rowId = annotatedClass.getAnnotation( RowId.class );
|
|
|
|
final View view = annotatedClass.getAnnotation( View.class );
|
|
|
|
final View view = annotatedClass.getAnnotation( View.class );
|
|
|
|
bindTable(
|
|
|
|
bindTable(
|
|
|
@ -794,7 +795,7 @@ public class EntityBinder {
|
|
|
|
rowId == null ? null : rowId.value(),
|
|
|
|
rowId == null ? null : rowId.value(),
|
|
|
|
view == null ? null : view.query(),
|
|
|
|
view == null ? null : view.query(),
|
|
|
|
inheritanceState.hasDenormalizedTable()
|
|
|
|
inheritanceState.hasDenormalizedTable()
|
|
|
|
? collector.getEntityTableXref( superEntity.getEntityName() )
|
|
|
|
? context.getMetadataCollector().getEntityTableXref( superEntity.getEntityName() )
|
|
|
|
: null
|
|
|
|
: null
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -951,12 +952,10 @@ public class EntityBinder {
|
|
|
|
discriminatorColumn.linkWithValue( discriminatorColumnBinding );
|
|
|
|
discriminatorColumn.linkWithValue( discriminatorColumnBinding );
|
|
|
|
discriminatorColumnBinding.setTypeName( discriminatorColumn.getDiscriminatorTypeName() );
|
|
|
|
discriminatorColumnBinding.setTypeName( discriminatorColumn.getDiscriminatorTypeName() );
|
|
|
|
rootClass.setPolymorphic( true );
|
|
|
|
rootClass.setPolymorphic( true );
|
|
|
|
if ( LOG.isTraceEnabled() ) {
|
|
|
|
final String rootEntityName = rootClass.getEntityName();
|
|
|
|
LOG.tracev( "Setting discriminator for entity {0}", rootClass.getEntityName() );
|
|
|
|
LOG.tracev( "Setting discriminator for entity {0}", rootEntityName);
|
|
|
|
}
|
|
|
|
context.getMetadataCollector()
|
|
|
|
context.getMetadataCollector().addSecondPass(
|
|
|
|
.addSecondPass( new NullableDiscriminatorColumnSecondPass( rootEntityName ) );
|
|
|
|
new NullableDiscriminatorColumnSecondPass( rootClass.getEntityName() )
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1274,14 +1273,14 @@ public class EntityBinder {
|
|
|
|
|
|
|
|
|
|
|
|
private void bindOptimisticLocking() {
|
|
|
|
private void bindOptimisticLocking() {
|
|
|
|
final OptimisticLocking optimisticLockingAnn = annotatedClass.getAnnotation( OptimisticLocking.class );
|
|
|
|
final OptimisticLocking optimisticLockingAnn = annotatedClass.getAnnotation( OptimisticLocking.class );
|
|
|
|
persistentClass.setOptimisticLockStyle(
|
|
|
|
persistentClass.setOptimisticLockStyle( fromLockType( optimisticLockingAnn == null
|
|
|
|
getVersioning( optimisticLockingAnn == null ? OptimisticLockType.VERSION : optimisticLockingAnn.type() )
|
|
|
|
? OptimisticLockType.VERSION
|
|
|
|
);
|
|
|
|
: optimisticLockingAnn.type() ) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void bindPolymorphism() {
|
|
|
|
private void bindPolymorphism() {
|
|
|
|
final Polymorphism polymorphismAnn = annotatedClass.getAnnotation( Polymorphism.class );
|
|
|
|
final Polymorphism polymorphismAnn = annotatedClass.getAnnotation( Polymorphism.class );
|
|
|
|
polymorphismType = polymorphismAnn == null ? PolymorphismType.IMPLICIT : polymorphismAnn.type();
|
|
|
|
polymorphismType = polymorphismAnn == null ? IMPLICIT : polymorphismAnn.type();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void bindEntityAnnotation() {
|
|
|
|
private void bindEntityAnnotation() {
|
|
|
@ -1369,7 +1368,7 @@ public class EntityBinder {
|
|
|
|
private void bindRootEntity() {
|
|
|
|
private void bindRootEntity() {
|
|
|
|
final RootClass rootClass = (RootClass) persistentClass;
|
|
|
|
final RootClass rootClass = (RootClass) persistentClass;
|
|
|
|
rootClass.setMutable( isMutable() );
|
|
|
|
rootClass.setMutable( isMutable() );
|
|
|
|
rootClass.setExplicitPolymorphism( isExplicitPolymorphism( polymorphismType ) );
|
|
|
|
rootClass.setExplicitPolymorphism( polymorphismType == EXPLICIT );
|
|
|
|
if ( isNotEmpty( where ) ) {
|
|
|
|
if ( isNotEmpty( where ) ) {
|
|
|
|
rootClass.setWhere( where );
|
|
|
|
rootClass.setWhere( where );
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -1484,7 +1483,8 @@ public class EntityBinder {
|
|
|
|
|
|
|
|
|
|
|
|
private void bindSynchronize() {
|
|
|
|
private void bindSynchronize() {
|
|
|
|
if ( annotatedClass.isAnnotationPresent( Synchronize.class ) ) {
|
|
|
|
if ( annotatedClass.isAnnotationPresent( Synchronize.class ) ) {
|
|
|
|
final JdbcEnvironment jdbcEnvironment = context.getMetadataCollector().getDatabase().getJdbcEnvironment();
|
|
|
|
final JdbcEnvironment jdbcEnvironment =
|
|
|
|
|
|
|
|
context.getMetadataCollector().getDatabase().getJdbcEnvironment();
|
|
|
|
final Synchronize synchronize = annotatedClass.getAnnotation(Synchronize.class);
|
|
|
|
final Synchronize synchronize = annotatedClass.getAnnotation(Synchronize.class);
|
|
|
|
for ( String table : synchronize.value() ) {
|
|
|
|
for ( String table : synchronize.value() ) {
|
|
|
|
String physicalName = synchronize.logical() ? toPhysicalName( jdbcEnvironment, table ) : table;
|
|
|
|
String physicalName = synchronize.logical() ? toPhysicalName( jdbcEnvironment, table ) : table;
|
|
|
@ -1494,11 +1494,10 @@ public class EntityBinder {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private String toPhysicalName(JdbcEnvironment jdbcEnvironment, String logicalName) {
|
|
|
|
private String toPhysicalName(JdbcEnvironment jdbcEnvironment, String logicalName) {
|
|
|
|
|
|
|
|
final Identifier identifier =
|
|
|
|
|
|
|
|
jdbcEnvironment.getIdentifierHelper().toIdentifier( logicalName );
|
|
|
|
return context.getBuildingOptions().getPhysicalNamingStrategy()
|
|
|
|
return context.getBuildingOptions().getPhysicalNamingStrategy()
|
|
|
|
.toPhysicalTableName(
|
|
|
|
.toPhysicalTableName( identifier, jdbcEnvironment )
|
|
|
|
jdbcEnvironment.getIdentifierHelper().toIdentifier( logicalName ),
|
|
|
|
|
|
|
|
jdbcEnvironment
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
.render( jdbcEnvironment.getDialect() );
|
|
|
|
.render( jdbcEnvironment.getDialect() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1564,32 +1563,6 @@ public class EntityBinder {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private OptimisticLockStyle getVersioning(OptimisticLockType type) {
|
|
|
|
|
|
|
|
switch ( type ) {
|
|
|
|
|
|
|
|
case VERSION:
|
|
|
|
|
|
|
|
return OptimisticLockStyle.VERSION;
|
|
|
|
|
|
|
|
case NONE:
|
|
|
|
|
|
|
|
return OptimisticLockStyle.NONE;
|
|
|
|
|
|
|
|
case DIRTY:
|
|
|
|
|
|
|
|
return OptimisticLockStyle.DIRTY;
|
|
|
|
|
|
|
|
case ALL:
|
|
|
|
|
|
|
|
return OptimisticLockStyle.ALL;
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
throw new AssertionFailure( "optimistic locking not supported: " + type );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private boolean isExplicitPolymorphism(PolymorphismType type) {
|
|
|
|
|
|
|
|
switch ( type ) {
|
|
|
|
|
|
|
|
case IMPLICIT:
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
case EXPLICIT:
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
throw new AssertionFailure( "Unknown polymorphism type: " + type );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public void bindProxy() {
|
|
|
|
public void bindProxy() {
|
|
|
|
final Proxy proxy = annotatedClass.getAnnotation( Proxy.class );
|
|
|
|
final Proxy proxy = annotatedClass.getAnnotation( Proxy.class );
|
|
|
|
if ( proxy != null ) {
|
|
|
|
if ( proxy != null ) {
|
|
|
@ -1823,23 +1796,21 @@ public class EntityBinder {
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public Identifier handleExplicitName(String explicitName, MetadataBuildingContext buildingContext) {
|
|
|
|
public Identifier handleExplicitName(String explicitName, MetadataBuildingContext buildingContext) {
|
|
|
|
return buildingContext.getMetadataCollector()
|
|
|
|
return jdbcEnvironment( buildingContext ).getIdentifierHelper().toIdentifier( explicitName );
|
|
|
|
.getDatabase()
|
|
|
|
|
|
|
|
.getJdbcEnvironment()
|
|
|
|
|
|
|
|
.getIdentifierHelper()
|
|
|
|
|
|
|
|
.toIdentifier( explicitName );
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public Identifier toPhysicalName(Identifier logicalName, MetadataBuildingContext buildingContext) {
|
|
|
|
public Identifier toPhysicalName(Identifier logicalName, MetadataBuildingContext buildingContext) {
|
|
|
|
return buildingContext.getBuildingOptions().getPhysicalNamingStrategy().toPhysicalTableName(
|
|
|
|
return buildingContext.getBuildingOptions().getPhysicalNamingStrategy()
|
|
|
|
logicalName,
|
|
|
|
.toPhysicalTableName( logicalName, jdbcEnvironment( buildingContext ) );
|
|
|
|
buildingContext.getMetadataCollector().getDatabase().getJdbcEnvironment()
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
private static JdbcEnvironment jdbcEnvironment(MetadataBuildingContext buildingContext) {
|
|
|
|
|
|
|
|
return buildingContext.getMetadataCollector().getDatabase().getJdbcEnvironment();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void bindTableForDiscriminatedSubclass(InFlightMetadataCollector.EntityTableXref superTableXref) {
|
|
|
|
public void bindTableForDiscriminatedSubclass(String entityName) {
|
|
|
|
if ( !(persistentClass instanceof SingleTableSubclass) ) {
|
|
|
|
if ( !(persistentClass instanceof SingleTableSubclass) ) {
|
|
|
|
throw new AssertionFailure(
|
|
|
|
throw new AssertionFailure(
|
|
|
|
"Was expecting a discriminated subclass [" + SingleTableSubclass.class.getName() +
|
|
|
|
"Was expecting a discriminated subclass [" + SingleTableSubclass.class.getName() +
|
|
|
@ -1848,12 +1819,14 @@ public class EntityBinder {
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
context.getMetadataCollector().addEntityTableXref(
|
|
|
|
final InFlightMetadataCollector collector = context.getMetadataCollector();
|
|
|
|
|
|
|
|
final InFlightMetadataCollector.EntityTableXref superTableXref =
|
|
|
|
|
|
|
|
collector.getEntityTableXref( entityName );
|
|
|
|
|
|
|
|
final Table primaryTable = superTableXref.getPrimaryTable();
|
|
|
|
|
|
|
|
collector.addEntityTableXref(
|
|
|
|
persistentClass.getEntityName(),
|
|
|
|
persistentClass.getEntityName(),
|
|
|
|
context.getMetadataCollector().getDatabase().toIdentifier(
|
|
|
|
collector.getDatabase().toIdentifier( collector.getLogicalTableName( primaryTable ) ),
|
|
|
|
context.getMetadataCollector().getLogicalTableName( superTableXref.getPrimaryTable() )
|
|
|
|
primaryTable,
|
|
|
|
),
|
|
|
|
|
|
|
|
superTableXref.getPrimaryTable(),
|
|
|
|
|
|
|
|
superTableXref
|
|
|
|
superTableXref
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -1867,12 +1840,12 @@ public class EntityBinder {
|
|
|
|
String viewQuery,
|
|
|
|
String viewQuery,
|
|
|
|
InFlightMetadataCollector.EntityTableXref denormalizedSuperTableXref) {
|
|
|
|
InFlightMetadataCollector.EntityTableXref denormalizedSuperTableXref) {
|
|
|
|
|
|
|
|
|
|
|
|
final EntityTableNamingStrategyHelper namingStrategyHelper = new EntityTableNamingStrategyHelper(
|
|
|
|
final String entityName = persistentClass.getEntityName();
|
|
|
|
persistentClass.getClassName(),
|
|
|
|
|
|
|
|
persistentClass.getEntityName(),
|
|
|
|
final EntityTableNamingStrategyHelper namingStrategyHelper =
|
|
|
|
name
|
|
|
|
new EntityTableNamingStrategyHelper( persistentClass.getClassName(), entityName, name );
|
|
|
|
);
|
|
|
|
final Identifier logicalName =
|
|
|
|
final Identifier logicalName = isNotEmpty( tableName )
|
|
|
|
isNotEmpty( tableName )
|
|
|
|
? namingStrategyHelper.handleExplicitName( tableName, context )
|
|
|
|
? namingStrategyHelper.handleExplicitName( tableName, context )
|
|
|
|
: namingStrategyHelper.determineImplicitName( context );
|
|
|
|
: namingStrategyHelper.determineImplicitName( context );
|
|
|
|
|
|
|
|
|
|
|
@ -1895,15 +1868,11 @@ public class EntityBinder {
|
|
|
|
// table.setComment( comment.value() );
|
|
|
|
// table.setComment( comment.value() );
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
|
|
context.getMetadataCollector().addEntityTableXref(
|
|
|
|
context.getMetadataCollector()
|
|
|
|
persistentClass.getEntityName(),
|
|
|
|
.addEntityTableXref( entityName, logicalName, table, denormalizedSuperTableXref );
|
|
|
|
logicalName,
|
|
|
|
|
|
|
|
table,
|
|
|
|
|
|
|
|
denormalizedSuperTableXref
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if ( persistentClass instanceof TableOwner ) {
|
|
|
|
if ( persistentClass instanceof TableOwner ) {
|
|
|
|
LOG.debugf( "Bind entity %s on table %s", persistentClass.getEntityName(), table.getName() );
|
|
|
|
LOG.debugf( "Bind entity %s on table %s", entityName, table.getName() );
|
|
|
|
( (TableOwner) persistentClass ).setTable( table );
|
|
|
|
( (TableOwner) persistentClass ).setTable( table );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
else {
|
|
|
@ -1934,13 +1903,16 @@ public class EntityBinder {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void createPrimaryColumnsToSecondaryTable(Object column, PropertyHolder propertyHolder, Join join) {
|
|
|
|
private void createPrimaryColumnsToSecondaryTable(Object column, PropertyHolder propertyHolder, Join join) {
|
|
|
|
final PrimaryKeyJoinColumn[] pkColumnsAnn = column instanceof PrimaryKeyJoinColumn[]
|
|
|
|
final PrimaryKeyJoinColumn[] pkColumnsAnn =
|
|
|
|
|
|
|
|
column instanceof PrimaryKeyJoinColumn[]
|
|
|
|
? (PrimaryKeyJoinColumn[]) column
|
|
|
|
? (PrimaryKeyJoinColumn[]) column
|
|
|
|
: null;
|
|
|
|
: null;
|
|
|
|
final JoinColumn[] joinColumnsAnn = column instanceof JoinColumn[]
|
|
|
|
final JoinColumn[] joinColumnsAnn =
|
|
|
|
|
|
|
|
column instanceof JoinColumn[]
|
|
|
|
? (JoinColumn[]) column
|
|
|
|
? (JoinColumn[]) column
|
|
|
|
: null;
|
|
|
|
: null;
|
|
|
|
final AnnotatedJoinColumns annotatedJoinColumns = pkColumnsAnn == null && joinColumnsAnn == null
|
|
|
|
final AnnotatedJoinColumns annotatedJoinColumns =
|
|
|
|
|
|
|
|
pkColumnsAnn == null && joinColumnsAnn == null
|
|
|
|
? createDefaultJoinColumn( propertyHolder )
|
|
|
|
? createDefaultJoinColumn( propertyHolder )
|
|
|
|
: createJoinColumns( propertyHolder, pkColumnsAnn, joinColumnsAnn );
|
|
|
|
: createJoinColumns( propertyHolder, pkColumnsAnn, joinColumnsAnn );
|
|
|
|
|
|
|
|
|
|
|
@ -1979,7 +1951,8 @@ public class EntityBinder {
|
|
|
|
columns.setJoins( secondaryTables );
|
|
|
|
columns.setJoins( secondaryTables );
|
|
|
|
columns.setPropertyHolder( propertyHolder );
|
|
|
|
columns.setPropertyHolder( propertyHolder );
|
|
|
|
for ( int colIndex = 0; colIndex < joinColumnCount; colIndex++ ) {
|
|
|
|
for ( int colIndex = 0; colIndex < joinColumnCount; colIndex++ ) {
|
|
|
|
final PrimaryKeyJoinColumn primaryKeyJoinColumn = primaryKeyJoinColumns != null ? primaryKeyJoinColumns[colIndex] : null;
|
|
|
|
final PrimaryKeyJoinColumn primaryKeyJoinColumn =
|
|
|
|
|
|
|
|
primaryKeyJoinColumns != null ? primaryKeyJoinColumns[colIndex] : null;
|
|
|
|
final JoinColumn joinColumn = joinColumns != null ? joinColumns[colIndex] : null;
|
|
|
|
final JoinColumn joinColumn = joinColumns != null ? joinColumns[colIndex] : null;
|
|
|
|
buildInheritanceJoinColumn(
|
|
|
|
buildInheritanceJoinColumn(
|
|
|
|
primaryKeyJoinColumn,
|
|
|
|
primaryKeyJoinColumn,
|
|
|
@ -1998,7 +1971,7 @@ public class EntityBinder {
|
|
|
|
join.setKey( key );
|
|
|
|
join.setKey( key );
|
|
|
|
setForeignKeyNameIfDefined( join );
|
|
|
|
setForeignKeyNameIfDefined( join );
|
|
|
|
key.setOnDeleteAction( null );
|
|
|
|
key.setOnDeleteAction( null );
|
|
|
|
TableBinder.bindForeignKey( persistentClass, null, joinColumns, key, false, context );
|
|
|
|
bindForeignKey( persistentClass, null, joinColumns, key, false, context );
|
|
|
|
key.sortProperties();
|
|
|
|
key.sortProperties();
|
|
|
|
join.createPrimaryKey();
|
|
|
|
join.createPrimaryKey();
|
|
|
|
join.createForeignKey();
|
|
|
|
join.createForeignKey();
|
|
|
@ -2106,16 +2079,16 @@ public class EntityBinder {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static <T extends Annotation> String tableMember(Class<T> annotationType, T sqlAnnotation) {
|
|
|
|
private static <T extends Annotation> String tableMember(Class<T> annotationType, T sqlAnnotation) {
|
|
|
|
if (SQLInsert.class.equals(annotationType)) {
|
|
|
|
if (SQLInsert.class == annotationType) {
|
|
|
|
return ((SQLInsert) sqlAnnotation).table();
|
|
|
|
return ((SQLInsert) sqlAnnotation).table();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (SQLUpdate.class.equals(annotationType)) {
|
|
|
|
else if (SQLUpdate.class == annotationType) {
|
|
|
|
return ((SQLUpdate) sqlAnnotation).table();
|
|
|
|
return ((SQLUpdate) sqlAnnotation).table();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (SQLDelete.class.equals(annotationType)) {
|
|
|
|
else if (SQLDelete.class == annotationType) {
|
|
|
|
return ((SQLDelete) sqlAnnotation).table();
|
|
|
|
return ((SQLDelete) sqlAnnotation).table();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (SQLDeleteAll.class.equals(annotationType)) {
|
|
|
|
else if (SQLDeleteAll.class == annotationType) {
|
|
|
|
return ((SQLDeleteAll) sqlAnnotation).table();
|
|
|
|
return ((SQLDeleteAll) sqlAnnotation).table();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
else {
|
|
|
@ -2124,13 +2097,13 @@ public class EntityBinder {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static <T extends Annotation> Annotation[] valueMember(Class<T> repeatableType, T sqlAnnotation) {
|
|
|
|
private static <T extends Annotation> Annotation[] valueMember(Class<T> repeatableType, T sqlAnnotation) {
|
|
|
|
if (SQLInserts.class.equals(repeatableType)) {
|
|
|
|
if (SQLInserts.class == repeatableType) {
|
|
|
|
return ((SQLInserts) sqlAnnotation).value();
|
|
|
|
return ((SQLInserts) sqlAnnotation).value();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (SQLUpdates.class.equals(repeatableType)) {
|
|
|
|
else if (SQLUpdates.class == repeatableType) {
|
|
|
|
return ((SQLUpdates) sqlAnnotation).value();
|
|
|
|
return ((SQLUpdates) sqlAnnotation).value();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (SQLDeletes.class.equals(repeatableType)) {
|
|
|
|
else if (SQLDeletes.class == repeatableType) {
|
|
|
|
return ((SQLDeletes) sqlAnnotation).value();
|
|
|
|
return ((SQLDeletes) sqlAnnotation).value();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
else {
|
|
|
@ -2217,9 +2190,10 @@ public class EntityBinder {
|
|
|
|
final Join join = new Join();
|
|
|
|
final Join join = new Join();
|
|
|
|
persistentClass.addJoin( join );
|
|
|
|
persistentClass.addJoin( join );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
final String entityName = persistentClass.getEntityName();
|
|
|
|
final InFlightMetadataCollector.EntityTableXref tableXref
|
|
|
|
final InFlightMetadataCollector.EntityTableXref tableXref
|
|
|
|
= context.getMetadataCollector().getEntityTableXref( persistentClass.getEntityName() );
|
|
|
|
= context.getMetadataCollector().getEntityTableXref( entityName );
|
|
|
|
assert tableXref != null : "Could not locate EntityTableXref for entity [" + persistentClass.getEntityName() + "]";
|
|
|
|
assert tableXref != null : "Could not locate EntityTableXref for entity [" + entityName + "]";
|
|
|
|
tableXref.addSecondaryTable( logicalName, join );
|
|
|
|
tableXref.addSecondaryTable( logicalName, join );
|
|
|
|
|
|
|
|
|
|
|
|
// No check constraints available on joins
|
|
|
|
// No check constraints available on joins
|
|
|
@ -2228,7 +2202,7 @@ public class EntityBinder {
|
|
|
|
// Somehow keep joins() for later.
|
|
|
|
// Somehow keep joins() for later.
|
|
|
|
// Has to do the work later because it needs PersistentClass id!
|
|
|
|
// Has to do the work later because it needs PersistentClass id!
|
|
|
|
LOG.debugf( "Adding secondary table to entity %s -> %s",
|
|
|
|
LOG.debugf( "Adding secondary table to entity %s -> %s",
|
|
|
|
persistentClass.getEntityName(), join.getTable().getName() );
|
|
|
|
entityName, join.getTable().getName() );
|
|
|
|
|
|
|
|
|
|
|
|
handleSecondaryRowManagement( join );
|
|
|
|
handleSecondaryRowManagement( join );
|
|
|
|
processSecondaryTableCustomSql( join );
|
|
|
|
processSecondaryTableCustomSql( join );
|
|
|
@ -2273,8 +2247,10 @@ public class EntityBinder {
|
|
|
|
|
|
|
|
|
|
|
|
private void processSecondaryTableCustomSql(Join join) {
|
|
|
|
private void processSecondaryTableCustomSql(Join join) {
|
|
|
|
final String tableName = join.getTable().getQuotedName();
|
|
|
|
final String tableName = join.getTable().getQuotedName();
|
|
|
|
final org.hibernate.annotations.Table matchingTable = findMatchingComplementaryTableAnnotation( tableName );
|
|
|
|
final org.hibernate.annotations.Table matchingTable =
|
|
|
|
final SQLInsert sqlInsert = findMatchingSqlAnnotation( tableName, SQLInsert.class, SQLInserts.class );
|
|
|
|
findMatchingComplementaryTableAnnotation( tableName );
|
|
|
|
|
|
|
|
final SQLInsert sqlInsert =
|
|
|
|
|
|
|
|
findMatchingSqlAnnotation( tableName, SQLInsert.class, SQLInserts.class );
|
|
|
|
if ( sqlInsert != null ) {
|
|
|
|
if ( sqlInsert != null ) {
|
|
|
|
join.setCustomSQLInsert(
|
|
|
|
join.setCustomSQLInsert(
|
|
|
|
sqlInsert.sql().trim(),
|
|
|
|
sqlInsert.sql().trim(),
|
|
|
@ -2296,7 +2272,8 @@ public class EntityBinder {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
final SQLUpdate sqlUpdate = findMatchingSqlAnnotation( tableName, SQLUpdate.class, SQLUpdates.class );
|
|
|
|
final SQLUpdate sqlUpdate =
|
|
|
|
|
|
|
|
findMatchingSqlAnnotation( tableName, SQLUpdate.class, SQLUpdates.class );
|
|
|
|
if ( sqlUpdate != null ) {
|
|
|
|
if ( sqlUpdate != null ) {
|
|
|
|
join.setCustomSQLUpdate(
|
|
|
|
join.setCustomSQLUpdate(
|
|
|
|
sqlUpdate.sql().trim(),
|
|
|
|
sqlUpdate.sql().trim(),
|
|
|
@ -2318,7 +2295,8 @@ public class EntityBinder {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
final SQLDelete sqlDelete = findMatchingSqlAnnotation( tableName, SQLDelete.class, SQLDeletes.class );
|
|
|
|
final SQLDelete sqlDelete =
|
|
|
|
|
|
|
|
findMatchingSqlAnnotation( tableName, SQLDelete.class, SQLDeletes.class );
|
|
|
|
if ( sqlDelete != null ) {
|
|
|
|
if ( sqlDelete != null ) {
|
|
|
|
join.setCustomSQLDelete(
|
|
|
|
join.setCustomSQLDelete(
|
|
|
|
sqlDelete.sql().trim(),
|
|
|
|
sqlDelete.sql().trim(),
|
|
|
|