Package org.datanucleus.metadata
Class AbstractClassMetaData
- java.lang.Object
- 
- org.datanucleus.metadata.MetaData
- 
- org.datanucleus.metadata.AbstractClassMetaData
 
 
- 
- All Implemented Interfaces:
- Serializable
 - Direct Known Subclasses:
- ClassMetaData,- InterfaceMetaData
 
 public abstract class AbstractClassMetaData extends MetaData Abstract representation of the MetaData of a class/interface. Has a parent PackageMetaData that can contain the metadata for several classes/interfaces. Is extended by ClassMetaData and InterfaceMetaData. Of the things that it contains the main ones are the "members" which are the MetaData for all fields and properties that are persistable.- See Also:
- Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected BooleanaccessViaFieldWhether the class has been explicitly marked as using FIELD access (JPA/Jakarta).protected int[]allMemberPositionsPositions of all fields/properties (inc superclasses).protected Booleancacheablecacheable tag value.protected StringcatalogCatalog name (O/R mapping).protected intcreateTimestampMemberPositionprotected intcreateUserMemberPositionprotected DatastoreIdentityMetaDatadatastoreIdentityMetaDataprotected booleandetachabledetachable tag value.protected boolean[]dfgMemberFlagsFlags of the default-fetch-group state for all fields/properties.protected int[]dfgMemberPositionsPositions of the default-fetch-group fields/properties (inc superclasses).protected booleanembeddedOnlyembedded-only tag value.protected StringentityNameEntity name.protected BooleanexcludeDefaultListenersFlag to exclude default listeners.protected BooleanexcludeSuperClassListenersFlag to exclude superclass listeners.protected Map<String,FetchGroupMetaData>fetchGroupMetaDataByNameConvenience lookup map of fetch group by the name.protected BooleanfetchGroupMetaWithPostLoadCached result ofhasFetchGroupWithPostLoad()protected Set<FetchGroupMetaData>fetchGroupsprotected List<ForeignKeyMetaData>foreignKeysprotected StringfullNameFull name (e.g org.datanucleus.MyClass)static StringGENERATED_PK_SUFFIXSuffix to add on to the class name for any generated primary key class.protected BooleanhasRelationsCached result ofhasRelations(ClassLoaderResolver)protected booleanidentitySpecifiedFlag whether the identity was specified by the user.protected IdentityTypeidentityTypeIdentity-type tag value.protected booleanimplementationOfPersistentDefinitionprotected List<IndexMetaData>indexesprotected InheritanceMetaDatainheritanceMetaDataprotected booleaninstantiableWhether the class is fully defined, and hence instantiable.protected List<JoinMetaData>joinsprotected List<EventListenerMetaData>listenersEventListeners.protected AbstractMemberMetaData[]managedMembersManaged fields/properties of this class.protected booleanmappedSuperclassWhether this class is explicitly marked as MappedSuperclass.protected intmemberCountnumber of managed fields/properties from this class plus inherited classes.protected Map<String,Integer>memberPositionsByNamePosition numbers of members mapped by the name of the field/property.protected List<AbstractMemberMetaData>membersList of all members (fields/properties).protected booleanmetaDataCompleteFlag for whether the MetaData here is complete without annotations.protected MetaDataManagermmgrManager for this metadata.protected MultitenancyMetaDatamultitenancyMetaDataprotected StringnameClass nameprotected boolean[]nonPkMemberFlagsFlags of the non-primary key fields/properties (inc superclasses).protected int[]nonPkMemberPositionsPositions of the non-primary-key fields/properties (inc superclasses).protected intnoOfInheritedManagedMembersNo of managed fields/properties in superclasses, that are inherited by this class.protected StringobjectidClassobjectid-class tag value.protected AbstractMemberMetaData[]overriddenMembersFields/properties for superclasses that are overridden in this class.protected AbstractClassMetaDatapcSuperclassMetaDataClass MetaData for the persistable superclass (if any)protected StringpersistableSuperclasspersistable-superclass tag value (deprecated).protected ClassPersistenceModifierpersistenceModifierpersistence-modifier tag value.protected booleanpersistentInterfaceImplNeedingTableFromSubclassImplementation of "persistent-interface" needing table setting from subclass.protected booleanpersistentInterfaceImplNeedingTableFromSuperclassImplementation of "persistent-interface" needing table setting from superclass.protected BooleanpkIsDatastoreAttributedCached result ofpkIsDatastoreAttributed(StoreManager)protected int[]pkMemberPositionsPositions of the primary-key fields/properties (inc superclasses).protected PrimaryKeyMetaDataprimaryKeyMetaDataprotected Collection<QueryMetaData>queriesNamed queriesprotected Collection<QueryResultMetaData>queryResultMetaDataList of query result MetaData defined for this file.protected int[]relationPositionsAbsolute positions of the fields/properties that have relations.protected booleanrequiresExtentrequires-extent tag value.protected StringschemaSchema name (O/R mapping).protected boolean[]scoContainerMemberFlagsprotected boolean[]scoMutableMemberFlagsFlags of the SCO mutable state for all fields/properties.protected int[]scoMutableMemberPositionsPositions of the SCO mutable fields/properties (inc superclasses).protected int[]scoNonContainerMemberPositionsAbsolute positions of all SCO fields/properties that aren't containers.protected booleanserializeReadWhether to lock objects of this type on read operations.protected SoftDeleteMetaDatasoftDeleteMetaDataprotected Collection<StoredProcQueryMetaData>storedProcQueriesNamed stored procsprotected StringtableTable name (O/R mapping).protected List<UniqueMetaData>uniqueConstraintsprotected List<ColumnMetaData>unmappedColumnsThe columns that are present in the datastore yet not mapped to fields in this class.protected intupdateTimestampMemberPositionprotected intupdateUserMemberPositionprotected booleanusesSingleFieldIdentityClassif this persistable class uses SingleFieldIdentityprotected int[]valueGenerationMemberPositionsPositions of fields/properties that require value-generation to be assigned (non-null strategy).protected VersionMetaDataversionMetaData- 
Fields inherited from class org.datanucleus.metadata.MetaDataEXTENSION_CLASS_CREATETIMESTAMP, EXTENSION_CLASS_CREATETIMESTAMP_COLUMN_NAME, EXTENSION_CLASS_CREATEUSER, EXTENSION_CLASS_CREATEUSER_COLUMN_LENGTH, EXTENSION_CLASS_CREATEUSER_COLUMN_NAME, EXTENSION_CLASS_MULTITENANCY_COLUMN_LENGTH, EXTENSION_CLASS_MULTITENANCY_COLUMN_NAME, EXTENSION_CLASS_MULTITENANCY_JDBC_TYPE, EXTENSION_CLASS_MULTITENANT, EXTENSION_CLASS_READ_ONLY, EXTENSION_CLASS_SOFTDELETE, EXTENSION_CLASS_SOFTDELETE_COLUMN_NAME, EXTENSION_CLASS_UPDATETIMESTAMP, EXTENSION_CLASS_UPDATETIMESTAMP_COLUMN_NAME, EXTENSION_CLASS_UPDATEUSER, EXTENSION_CLASS_UPDATEUSER_COLUMN_LENGTH, EXTENSION_CLASS_UPDATEUSER_COLUMN_NAME, EXTENSION_CLASS_VERSION_FIELD_NAME, EXTENSION_CLASS_VIEW_DEFINITION, EXTENSION_CLASS_VIEW_IMPORTS, EXTENSION_INDEX_COLUMN_ORDERING, EXTENSION_MEMBER_CACHEABLE, EXTENSION_MEMBER_CALENDAR_ONE_COLUMN, EXTENSION_MEMBER_CASCADE_ATTACH, EXTENSION_MEMBER_CASCADE_DETACH, EXTENSION_MEMBER_CASCADE_PERSIST, EXTENSION_MEMBER_CASCADE_REFRESH, EXTENSION_MEMBER_COMPARATOR_NAME, EXTENSION_MEMBER_CONTAINER_ALLOW_NULLS, EXTENSION_MEMBER_CREATE_TIMESTAMP, EXTENSION_MEMBER_CREATE_USER, EXTENSION_MEMBER_ENUM_VALUE_GETTER, EXTENSION_MEMBER_IMPLEMENTATION_CLASSES, EXTENSION_MEMBER_INSERTABLE, EXTENSION_MEMBER_KEY_IMPLEMENTATION_CLASSES, EXTENSION_MEMBER_LIST_ORDERING, EXTENSION_MEMBER_RELATION_DISCRIM_COLUMN, EXTENSION_MEMBER_RELATION_DISCRIM_PK, EXTENSION_MEMBER_RELATION_DISCRIM_VALUE, EXTENSION_MEMBER_STRATEGY_WHEN_NOTNULL, EXTENSION_MEMBER_TYPE_CONVERTER_DISABLED, EXTENSION_MEMBER_TYPE_CONVERTER_NAME, EXTENSION_MEMBER_UPDATE_TIMESTAMP, EXTENSION_MEMBER_UPDATE_USER, EXTENSION_MEMBER_UPDATEABLE, EXTENSION_MEMBER_VALUE_IMPLEMENTATION_CLASSES, EXTENSION_VERSION_NUMBER_INITIAL_VALUE, extensions, metaDataState, parent, VENDOR_NAME
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description AbstractClassMetaData(ClassMetaData cmd, String implClassName)Constructor for creating the ClassMetaData for an implementation of a "persistent-abstract-class".AbstractClassMetaData(InterfaceMetaData imd, String implClassName, boolean copyMembers)Constructor for creating the ClassMetaData for an implementation of a "persistent-interface".protectedAbstractClassMetaData(PackageMetaData parent, String name)Constructor.
 - 
Method SummaryAll Methods Static Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddFetchGroup(FetchGroupMetaData fgmd)Method to add a fetch-group to this class.voidaddForeignKey(ForeignKeyMetaData fkmd)Method to add an foreign-key to this class.voidaddIndex(IndexMetaData idxmd)Method to add an index to this class.voidaddJoin(JoinMetaData jnmd)Method to add a join to this class.voidaddListener(EventListenerMetaData listener)Add a listener class namevoidaddMember(AbstractMemberMetaData mmd)Method to add a field/property to this interface.voidaddQuery(QueryMetaData qmd)Method to add a named query to this class.voidaddQueryResultMetaData(QueryResultMetaData resultMetaData)Method to register a query-result MetaData.voidaddStoredProcQuery(StoredProcQueryMetaData qmd)Method to add a named stored proc query to this class.voidaddUniqueConstraint(UniqueMetaData unimd)Method to add a unique constraint to this class.voidaddUnmappedColumn(ColumnMetaData colmd)Method to add an unmapped column.protected voidapplyDefaultDiscriminatorValueWhenNotSpecified()protected static voidcheckForCircularViewReferences(Map<String,Set<String>> viewReferences, String referencerName, String referenceeName, List<String> referenceChain)Check for any circular view references between referencer and referencee.protected voidcheckInitialised()Method to check whether the Meta-Data has been initialised.protected voidcheckNotYetPopulated()Method to check that the Meta-Data has not been populated yet.protected voidcheckPopulated()Method to check whether the Meta-Data has been populated.protected voiddetermineIdentity()Determines the identity based on MetaData defaults or user defined MetaDataprotected voiddetermineInheritanceMetaData()Impose a default inheritance strategy when one is not already specified.protected voiddetermineObjectIdClass()Determine the object id class.protected voiddetermineSuperClassName(ClassLoaderResolver clr, Class cls)Determine the nearest superclass that is persistable (if any).voidexcludeDefaultListeners()Method to exclude default listeners.voidexcludeSuperClassListeners()Toogle exclude super class listenersintgetAbsolutePositionOfMember(String memberName)Accessor for the absolute position of the field/property with the specified name.BooleangetAccessViaField()int[]getAllMemberPositions()Accessor for all field/property positions.AbstractClassMetaDatagetBaseAbstractClassMetaData()Convenience accessor for the AbstractClassMetaData of the base object in this hierarchy.DatastoreIdentityMetaDatagetBaseDatastoreIdentityMetaData()Convenience method to return the root identity metadata for this inheritance tree.protected StringgetBaseInheritanceStrategy()int[]getBasicMemberPositions(ClassLoaderResolver clr)Accessor for the absolute positions of fields/properties that are considered basic.int[]getBidirectionalRelationMemberPositions(ClassLoaderResolver clr)Convenience method to return the absolute positions of fields/properties that have bidirectional relations.StringgetCatalog()intgetCreateTimestampMemberPosition()intgetCreateUserMemberPosition()DatastoreIdentityMetaDatagetDatastoreIdentityMetaData()Accessor for datastore identity MetaDataboolean[]getDFGMemberFlags()Accessor for the flags of the DFG fields/properties (inc superclass).int[]getDFGMemberPositions()Accessor for the absolute positions of the default fetch group fields/properties (inc superclasses).ColumnMetaDatagetDiscriminatorColumnMetaData()Return the metadata for the discriminator column if defined in metadata.StringgetDiscriminatorColumnName()Return the name of the discriminator column if defined in metadata.DiscriminatorMetaDatagetDiscriminatorMetaData()Convenience accessor for the discriminator metadata applying to this class.DiscriminatorMetaDatagetDiscriminatorMetaDataForTable()Convenience method to find the discriminator MetaData defining the discrim for the same table as this class is using.DiscriminatorMetaDatagetDiscriminatorMetaDataRoot()Convenience method to return the "root" discriminator metadata definition (that defines the strategy, column etc).DiscriminatorStrategygetDiscriminatorStrategy()Method to return the discriminator strategy being used by this class.DiscriminatorStrategygetDiscriminatorStrategyForTable()Convenience accessor for the discriminator strategy applying to this class.ObjectgetDiscriminatorValue()Method returning the discriminator value to apply to an instance of this class.StringgetEntityName()Set<FetchGroupMetaData>getFetchGroupMetaData()Accessor for all MetaData defined for fetch groups for this class.FetchGroupMetaDatagetFetchGroupMetaData(String groupname)Accessor for the fetch group metadata for the group specified.Set<FetchGroupMetaData>getFetchGroupMetaData(Collection<String> groupNames)Accessor for fetch group metadata for the specified groups (if present).List<ForeignKeyMetaData>getForeignKeyMetaData()StringgetFullClassName()Accessor for the full class name including any package name.IdentityTypegetIdentityType()List<IndexMetaData>getIndexMetaData()InheritanceMetaDatagetInheritanceMetaData()Accessor for inheritanceMetaDataList<JoinMetaData>getJoinMetaData()EventListenerMetaDatagetListenerForClass(String className)Accessor for the EventListener info for an EventListener class nameList<EventListenerMetaData>getListeners()Get the event listenersAbstractMemberMetaData[]getManagedMembers()Accessor for the managed fields/properties in this class (not including superclass, but including overridden).protected AbstractMemberMetaDatagetMemberBeingOverridden(String name)Convenience method that navigates up a MetaData inheritance tree until it finds the base member definition for the specified name.intgetMemberCount()Accessor for the number of managed members from this class plus inherited classes.AbstractMemberMetaDatagetMetaDataForManagedMemberAtAbsolutePosition(int position)Accessor for a managed member including superclass members.protected AbstractMemberMetaDatagetMetaDataForManagedMemberAtAbsolutePositionInternal(int abs_position)Internal method to get the field/property for an absolute field number.AbstractMemberMetaDatagetMetaDataForManagedMemberAtRelativePosition(int position)Accessor for MetaData for a managed member in this class.AbstractMemberMetaDatagetMetaDataForMember(String name)Accessor for the Meta-Data for a member.AbstractMemberMetaDatagetMetaDataForMemberAtRelativePosition(int index)Accessor for the metadata of a member.MetaDataManagergetMetaDataManager()MultitenancyMetaDatagetMultitenancyMetaData()int[]getMultivaluedMemberPositions()Accessor for the absolute positions of fields/properties that are considered multi-valued This category includes members of all multi-valued types, including Collection, array, and Map types of basic and relationship types.StringgetName()Accessor for the simple class name (without package name).boolean[]getNonPKMemberFlags()Accessor for the flags of the non primary key fields/properties (inc superclass members).int[]getNonPKMemberPositions()Accessor for the positions of the non primary key fields/properties (inc superclass fields).int[]getNonRelationMemberPositions(ClassLoaderResolver clr)intgetNoOfInheritedManagedMembers()Accessor for the number of inherited managed members in superclasses.intgetNoOfManagedMembers()Accessor for the number of managed members (this class only).intgetNoOfMembers()Accessor for the number of members defined for this class (including overrides).intgetNoOfPrimaryKeyMembers()Accessor for the number of primary key fields/properties.intgetNoOfQueries()Accessor for the number of named queries.intgetNoOfStoredProcQueries()Accessor for the number of named stored proc queries.StringgetObjectidClass()AbstractMemberMetaDatagetOverriddenMember(String name)Accessor for an overridden field/property with the specified name.AbstractMemberMetaData[]getOverriddenMembers()Accessor for the overridden fields/properties in this class.PackageMetaDatagetPackageMetaData()StringgetPackageName()StringgetPersistableSuperclass()ClassPersistenceModifiergetPersistenceModifier()int[]getPKMemberPositions()Accessor for the field numbers of the primary key fields/properties.String[]getPrimaryKeyMemberNames()Accessor for the names of the primary key fields/properties.PrimaryKeyMetaDatagetPrimaryKeyMetaData()Accessor for primaryKeyMetaDataQueryMetaData[]getQueries()Accessor for the metadata of the named queries.QueryResultMetaData[]getQueryResultMetaData()Get the query result MetaData registered for this class.int[]getRelationMemberPositions(ClassLoaderResolver clr)Convenience method to return the absolute positions of all fields/properties that have relations.intgetRelativePositionOfMember(String memberName)Accessor for the (relative) position of the field/property with the specified name.protected AbstractClassMetaDatagetRootInstantiableClass()StringgetSchema()boolean[]getSCOContainerMemberFlags()Accessor for the flags of whether members are SCO "containers" (Collection/Map/array).boolean[]getSCOMutableMemberFlags()Accessor for the flags of the SCO mutable fields (inc superclass fields).int[]getSCOMutableMemberPositions()Accessor for the absolute positions of the second class mutable fields/properties.int[]getSCONonContainerMemberPositions()Accessor for the absolute positions of all SCO fields/properties that are NOT containers (e.g Dates, Points, etc)SoftDeleteMetaDatagetSoftDeleteMetaData()StoredProcQueryMetaData[]getStoredProcQueries()Accessor for the metadata of the named stored proc queries.AbstractClassMetaDatagetSuperAbstractClassMetaData()Accessor for the Meta-Data for the superclass of this class.StringgetTable()List<UniqueMetaData>getUniqueMetaData()List<ColumnMetaData>getUnmappedColumns()Accessor for the unmapped columns required for the datastore table.intgetUpdateTimestampMemberPosition()intgetUpdateUserMemberPosition()int[]getValueGenerationMemberPositions()Accessor for the member positions which require value generation processing (non-null strategy).VersionMetaDatagetVersionMetaData()Accessor for Version MetaData for this class specifically.VersionMetaDatagetVersionMetaDataForClass()Convenience accessor for the version metadata applying to this class.VersionMetaDatagetVersionMetaDataForTable()Convenience method to find the version MetaData defining versioning for the same 'table' as this class is using.booleanhasDiscriminatorStrategy()Accessor for whether we have a discriminator defined for this class (may be in superclasses).booleanhasFetchGroupWithPostLoad()Whether this class or any super class has any fetch group definition withFetchGroupMetaData.getPostLoad()==true.booleanhasMember(String memberName)Method to check if a member exists in this classes definition.booleanhasRelations(ClassLoaderResolver clr)Convenience method to return if the class has relations to other objects.protected voidinheritIdentity()Inherit the identity definition from super classes.protected voidinitialiseMemberPositionInformation()Method to initialise all convenience information about member positions and what role each position performs.BooleanisCacheable()booleanisDescendantOf(AbstractClassMetaData cmd)Convenience method to return if this class is a descendant of the supplied class metadata.booleanisDetachable()booleanisEmbeddedOnly()booleanisExcludeDefaultListeners()Whether default listeners are not going to be invokedbooleanisExcludeSuperClassListeners()Whether super classes listeners are not going to be invokedbooleanisImplementationOfPersistentDefinition()Return whether this MetaData is for an implementation of a persistent definition.booleanisInstantiable()booleanisMappedSuperclass()booleanisMetaDataComplete()Accessor for whether this class is fully specified by this metadata and that any annotations should be ignored.booleanisRequiresExtent()booleanisRootInstantiableClass()booleanisSameOrAncestorOf(AbstractClassMetaData cmd)Check if the argument cmd is the same as this or a descedent.booleanisSerializeRead()booleanisSoftDelete()booleanisVersioned()Returns whether objects of this type are versioned.protected ClassloadClass(ClassLoaderResolver clr, ClassLoader primary)Load the persistent interface/classDatastoreIdentityMetaDatanewDatastoreIdentityMetaData()Method to create a new datastore identity metadata, set to use it, and return it.protected AbstractMemberMetaDatanewDefaultedProperty(String name)Utility to add a defaulted PropertyMetaData to the class.FetchGroupMetaDatanewFetchGroupMetaData(String name)Method to create a new fetchgroup metadata, add it, and return it.FieldMetaDatanewFieldMetaData(String fieldName)Method to create a new field metadata, add it, and return it.ForeignKeyMetaDatanewForeignKeyMetaData()Method to create a new FK metadata, add it, and return it.IndexMetaDatanewIndexMetaData()Method to create a new index metadata, add it, and return it.InheritanceMetaDatanewInheritanceMetaData()Method to create a new inheritance metadata, set to use it, and return it.JoinMetaDatanewJoinMetaData()Method to create a new join metadata, add it, and return it.MultitenancyMetaDatanewMultitenancyMetaData()PrimaryKeyMetaDatanewPrimaryKeyMetaData()Method to create a new primary key metadata, set to use it, and return it.PropertyMetaDatanewPropertyMetaData(String propName)Method to create a new property metadata, add it, and return it.QueryMetaDatanewQueryMetaData(String queryName)Method to create a new QueryMetadata, add it to the registered queries and return it.SoftDeleteMetaDatanewSoftDeleteMetaData()StoredProcQueryMetaDatanewStoredProcQueryMetaData(String queryName)Method to create a new StoredProcQueryMetadata, add it to the registered queries and return it.UniqueMetaDatanewUniqueMetaData()Method to create a new unique metadata, add it, and return it.ColumnMetaDatanewUnmappedColumnMetaData()VersionMetaDatanewVersionMetaData()Method to create a new version metadata, set to use it, and return it.booleanpkIsDatastoreAttributed(StoreManager storeMgr)Convenience method to calculate and return if the pk has some component that is generated in the datastore.abstract voidpopulate(ClassLoaderResolver clr, ClassLoader primary, MetaDataManager mmgr)Method to provide the details of the class being represented by this MetaData.voidsetAccessViaField(boolean flag)AbstractClassMetaDatasetCacheable(boolean cache)AbstractClassMetaDatasetCacheable(String cache)AbstractClassMetaDatasetCatalog(String catalog)voidsetDatastoreIdentityMetaData(DatastoreIdentityMetaData identityMetaData)Mutator for the datastore identity MetaData.AbstractClassMetaDatasetDetachable(boolean flag)AbstractClassMetaDatasetDetachable(String flag)AbstractClassMetaDatasetEmbeddedOnly(boolean flag)AbstractClassMetaDatasetEmbeddedOnly(String flag)AbstractClassMetaDatasetEntityName(String name)voidsetIdentityType(IdentityType type)voidsetInheritanceMetaData(InheritanceMetaData inheritanceMetaData)Mutator for the inheritance MetaData.voidsetMappedSuperclass(boolean mapped)voidsetMetaDataComplete()Method to set that this class is "metadata complete" (see JPA spec).voidsetMultitenancyMetaData(MultitenancyMetaData mtmd)AbstractClassMetaDatasetObjectIdClass(String objectidClass)AbstractClassMetaDatasetPersistenceModifier(ClassPersistenceModifier modifier)voidsetPrimaryKeyMetaData(PrimaryKeyMetaData primaryKeyMetaData)Mutator for the PrimaryKey MetaData.AbstractClassMetaDatasetRequiresExtent(boolean flag)AbstractClassMetaDatasetRequiresExtent(String flag)AbstractClassMetaDatasetSchema(String schema)voidsetSerializeRead(boolean serialise)voidsetSoftDeleteMetaData(SoftDeleteMetaData sdmd)AbstractClassMetaDatasetTable(String table)voidsetVersionMetaData(VersionMetaData versionMetaData)Mutator for the Version MetaData.booleanusesSingleFieldIdentityClass()Whether this persistable class uses SingleFieldIdentityprotected voidvalidateObjectIdClass(ClassLoaderResolver clr)Validate the objectid-class of this class.protected voidvalidateUnmappedColumns()Convenience method to validate the specified "unmapped" columns.protected voidvalidateUserInputForIdentity()Check for conflicts on super class and this class MetaData identityprotected voidvalidateUserInputForInheritanceMetaData(boolean isAbstract)Check if the inheritance MetaData is credible.- 
Methods inherited from class org.datanucleus.metadata.MetaDataaddExtension, addExtensions, getExtensions, getNoOfExtensions, getParent, getValueForExtension, getValuesForExtension, hasExtension, initialise, isInitialised, isPopulated, isUsed, removeExtension, setExtensions, setParent
 
- 
 
- 
- 
- 
Field Detail- 
GENERATED_PK_SUFFIXpublic static final String GENERATED_PK_SUFFIX Suffix to add on to the class name for any generated primary key class.- See Also:
- Constant Field Values
 
 - 
mmgrprotected transient MetaDataManager mmgr Manager for this metadata. Set at populate.
 - 
nameprotected final String name Class name
 - 
entityNameprotected String entityName Entity name. Required by JPA/Jakarta $4.3.1 for accessing this class in queries.
 - 
mappedSuperclassprotected boolean mappedSuperclass Whether this class is explicitly marked as MappedSuperclass. Will be false when using JDO.
 - 
instantiableprotected boolean instantiable Whether the class is fully defined, and hence instantiable. This is false when it is a JPA/Jakarta MappedSuperclass and has no PK fields defined (will be defined in the derived Entity). This is different to whether the class is abstract - use ClassMetaData.isAbstract() for that.
 - 
accessViaFieldprotected Boolean accessViaField Whether the class has been explicitly marked as using FIELD access (JPA/Jakarta).
 - 
identityTypeprotected IdentityType identityType Identity-type tag value.
 - 
persistenceModifierprotected ClassPersistenceModifier persistenceModifier persistence-modifier tag value.
 - 
persistableSuperclassprotected String persistableSuperclass persistable-superclass tag value (deprecated).
 - 
objectidClassprotected String objectidClass objectid-class tag value.
 - 
requiresExtentprotected boolean requiresExtent requires-extent tag value.
 - 
detachableprotected boolean detachable detachable tag value.
 - 
embeddedOnlyprotected boolean embeddedOnly embedded-only tag value.
 - 
catalogprotected String catalog Catalog name (O/R mapping).
 - 
schemaprotected String schema Schema name (O/R mapping).
 - 
tableprotected String table Table name (O/R mapping). This may be of the form "[database].[catalog].[schema].table"
 - 
cacheableprotected Boolean cacheable cacheable tag value.
 - 
fullNameprotected final String fullName Full name (e.g org.datanucleus.MyClass)
 - 
versionMetaDataprotected VersionMetaData versionMetaData 
 - 
datastoreIdentityMetaDataprotected DatastoreIdentityMetaData datastoreIdentityMetaData 
 - 
multitenancyMetaDataprotected MultitenancyMetaData multitenancyMetaData 
 - 
softDeleteMetaDataprotected SoftDeleteMetaData softDeleteMetaData 
 - 
identitySpecifiedprotected boolean identitySpecified Flag whether the identity was specified by the user.
 - 
inheritanceMetaDataprotected InheritanceMetaData inheritanceMetaData 
 - 
primaryKeyMetaDataprotected PrimaryKeyMetaData primaryKeyMetaData 
 - 
listenersprotected List<EventListenerMetaData> listeners EventListeners. Use a list to preserve ordering.
 - 
excludeSuperClassListenersprotected Boolean excludeSuperClassListeners Flag to exclude superclass listeners.
 - 
excludeDefaultListenersprotected Boolean excludeDefaultListeners Flag to exclude default listeners.
 - 
fetchGroupMetaDataByNameprotected Map<String,FetchGroupMetaData> fetchGroupMetaDataByName Convenience lookup map of fetch group by the name.
 - 
pcSuperclassMetaDataprotected AbstractClassMetaData pcSuperclassMetaData Class MetaData for the persistable superclass (if any)
 - 
metaDataCompleteprotected boolean metaDataComplete Flag for whether the MetaData here is complete without annotations. Used by JPA.
 - 
serializeReadprotected boolean serializeRead Whether to lock objects of this type on read operations.
 - 
queriesprotected Collection<QueryMetaData> queries Named queries
 - 
storedProcQueriesprotected Collection<StoredProcQueryMetaData> storedProcQueries Named stored procs
 - 
queryResultMetaDataprotected Collection<QueryResultMetaData> queryResultMetaData List of query result MetaData defined for this file.
 - 
unmappedColumnsprotected List<ColumnMetaData> unmappedColumns The columns that are present in the datastore yet not mapped to fields in this class.
 - 
fetchGroupsprotected Set<FetchGroupMetaData> fetchGroups 
 - 
foreignKeysprotected List<ForeignKeyMetaData> foreignKeys 
 - 
indexesprotected List<IndexMetaData> indexes 
 - 
uniqueConstraintsprotected List<UniqueMetaData> uniqueConstraints 
 - 
joinsprotected List<JoinMetaData> joins 
 - 
membersprotected List<AbstractMemberMetaData> members List of all members (fields/properties).
 - 
managedMembersprotected AbstractMemberMetaData[] managedMembers Managed fields/properties of this class. Subset of the AbstractMemberMetaData objects that are in "members", excluding "overriddenMembers".
 - 
overriddenMembersprotected AbstractMemberMetaData[] overriddenMembers Fields/properties for superclasses that are overridden in this class.
 - 
memberPositionsByNameprotected Map<String,Integer> memberPositionsByName Position numbers of members mapped by the name of the field/property.
 - 
allMemberPositionsprotected int[] allMemberPositions Positions of all fields/properties (inc superclasses).
 - 
pkMemberPositionsprotected int[] pkMemberPositions Positions of the primary-key fields/properties (inc superclasses).
 - 
nonPkMemberPositionsprotected int[] nonPkMemberPositions Positions of the non-primary-key fields/properties (inc superclasses).
 - 
nonPkMemberFlagsprotected boolean[] nonPkMemberFlags Flags of the non-primary key fields/properties (inc superclasses).
 - 
dfgMemberPositionsprotected int[] dfgMemberPositions Positions of the default-fetch-group fields/properties (inc superclasses).
 - 
dfgMemberFlagsprotected boolean[] dfgMemberFlags Flags of the default-fetch-group state for all fields/properties.
 - 
valueGenerationMemberPositionsprotected int[] valueGenerationMemberPositions Positions of fields/properties that require value-generation to be assigned (non-null strategy).
 - 
createTimestampMemberPositionprotected int createTimestampMemberPosition 
 - 
updateTimestampMemberPositionprotected int updateTimestampMemberPosition 
 - 
createUserMemberPositionprotected int createUserMemberPosition 
 - 
updateUserMemberPositionprotected int updateUserMemberPosition 
 - 
scoMutableMemberPositionsprotected int[] scoMutableMemberPositions Positions of the SCO mutable fields/properties (inc superclasses).
 - 
scoMutableMemberFlagsprotected boolean[] scoMutableMemberFlags Flags of the SCO mutable state for all fields/properties.
 - 
scoContainerMemberFlagsprotected boolean[] scoContainerMemberFlags 
 - 
scoNonContainerMemberPositionsprotected int[] scoNonContainerMemberPositions Absolute positions of all SCO fields/properties that aren't containers.
 - 
relationPositionsprotected int[] relationPositions Absolute positions of the fields/properties that have relations.
 - 
noOfInheritedManagedMembersprotected int noOfInheritedManagedMembers No of managed fields/properties in superclasses, that are inherited by this class.
 - 
usesSingleFieldIdentityClassprotected boolean usesSingleFieldIdentityClass if this persistable class uses SingleFieldIdentity
 - 
memberCountprotected int memberCount number of managed fields/properties from this class plus inherited classes.
 - 
implementationOfPersistentDefinitionprotected boolean implementationOfPersistentDefinition 
 - 
fetchGroupMetaWithPostLoadprotected Boolean fetchGroupMetaWithPostLoad Cached result ofhasFetchGroupWithPostLoad()
 - 
pkIsDatastoreAttributedprotected Boolean pkIsDatastoreAttributed Cached result ofpkIsDatastoreAttributed(StoreManager)
 - 
hasRelationsprotected Boolean hasRelations Cached result ofhasRelations(ClassLoaderResolver)
 - 
persistentInterfaceImplNeedingTableFromSuperclassprotected transient boolean persistentInterfaceImplNeedingTableFromSuperclass Implementation of "persistent-interface" needing table setting from superclass.
 - 
persistentInterfaceImplNeedingTableFromSubclassprotected transient boolean persistentInterfaceImplNeedingTableFromSubclass Implementation of "persistent-interface" needing table setting from subclass.
 
- 
 - 
Constructor Detail- 
AbstractClassMetaDataprotected AbstractClassMetaData(PackageMetaData parent, String name) Constructor. Set fields using setters, before populate().- Parameters:
- parent- The package to which this class/interface belongs
- name- (Simple) name of class (omitting the package name)
 
 - 
AbstractClassMetaDatapublic AbstractClassMetaData(InterfaceMetaData imd, String implClassName, boolean copyMembers) Constructor for creating the ClassMetaData for an implementation of a "persistent-interface".- Parameters:
- imd- MetaData for the "persistent-interface"
- implClassName- Name of the implementation class
- copyMembers- Whether to copy the fields/properties of the interface too
 
 - 
AbstractClassMetaDatapublic AbstractClassMetaData(ClassMetaData cmd, String implClassName) Constructor for creating the ClassMetaData for an implementation of a "persistent-abstract-class".- Parameters:
- cmd- MetaData for the implementation of the "persistent-abstract-class"
- implClassName- Name of the implementation class
 
 
- 
 - 
Method Detail- 
getMetaDataManagerpublic MetaDataManager getMetaDataManager() - Overrides:
- getMetaDataManagerin class- MetaData
 
 - 
isInstantiablepublic boolean isInstantiable() 
 - 
getRootInstantiableClassprotected AbstractClassMetaData getRootInstantiableClass() 
 - 
isRootInstantiableClasspublic boolean isRootInstantiableClass() 
 - 
isImplementationOfPersistentDefinitionpublic boolean isImplementationOfPersistentDefinition() Return whether this MetaData is for an implementation of a persistent definition. This could be an implementation of a persistent interface or a persistent abstract-class.- Returns:
- Whether this is an implementation
 
 - 
checkInitialisedprotected void checkInitialised() Method to check whether the Meta-Data has been initialised.- Throws:
- NucleusException- Thrown if the Meta-Data hasn't been initialised.
 
 - 
checkPopulatedprotected void checkPopulated() Method to check whether the Meta-Data has been populated.- Throws:
- NucleusException- Thrown if the Meta-Data hasn't been populated.
 
 - 
checkNotYetPopulatedprotected void checkNotYetPopulated() Method to check that the Meta-Data has not been populated yet.- Throws:
- NucleusUserException- Thrown if the Meta-Data has already been populated.
 
 - 
loadClassprotected Class loadClass(ClassLoaderResolver clr, ClassLoader primary) Load the persistent interface/class- Parameters:
- clr- the ClassLoader
- primary- the primary ClassLoader to use (or null)
- Returns:
- the loaded class
 
 - 
determineIdentityprotected void determineIdentity() Determines the identity based on MetaData defaults or user defined MetaData
 - 
determineSuperClassNameprotected void determineSuperClassName(ClassLoaderResolver clr, Class cls) Determine the nearest superclass that is persistable (if any).- Parameters:
- clr- The ClassLoaderResolver
- cls- This class
- Throws:
- InvalidMetaDataException- if the super class cannot be loaded by the- clr.
- InvalidMetaDataException- if the declared- persistence-capable-superclassis not actually assignable from- cls
- InvalidMetaDataException- if any of the super classes is persistable, but the MetaData says that class is not persistent.
 
 - 
validateUserInputForIdentityprotected void validateUserInputForIdentity() Check for conflicts on super class and this class MetaData identity- Throws:
- InvalidMetaDataException- if the user tries to overwrite a superclass identity / strategy
 
 - 
getBaseAbstractClassMetaDatapublic AbstractClassMetaData getBaseAbstractClassMetaData() Convenience accessor for the AbstractClassMetaData of the base object in this hierarchy.- Returns:
- The AbstractClassMetaData for the base object.
 
 - 
isDescendantOfpublic boolean isDescendantOf(AbstractClassMetaData cmd) Convenience method to return if this class is a descendant of the supplied class metadata.- Parameters:
- cmd- The class to check against
- Returns:
- Whether the supplied metadata is an ancestor of this
 
 - 
getBaseInheritanceStrategyprotected String getBaseInheritanceStrategy() 
 - 
inheritIdentityprotected void inheritIdentity() Inherit the identity definition from super classes.- Throws:
- InvalidMetaDataException- if the MetaData of this class conflicts with super classes definition
 
 - 
newDefaultedPropertyprotected AbstractMemberMetaData newDefaultedProperty(String name) Utility to add a defaulted PropertyMetaData to the class. Provided as a method since then any derived classes can override it.- Parameters:
- name- name of property
- Returns:
- the new PropertyMetaData
 
 - 
validateUserInputForInheritanceMetaDataprotected void validateUserInputForInheritanceMetaData(boolean isAbstract) Check if the inheritance MetaData is credible.- Parameters:
- isAbstract- Whether this class is abstract
- Throws:
- InvalidMetaDataException- if the strategy is superclass-table, yet there are no super class
- InvalidMetaDataException- if the strategy is superclass-table, yet the super class has not specified a discriminator
- InvalidMetaDataException- if the strategy is superclass-table and discriminator is "value-map", yet no value for the discriminator has been specified
 
 - 
determineInheritanceMetaDataprotected void determineInheritanceMetaData() Impose a default inheritance strategy when one is not already specified. Uses the persistence property for defaultInheritanceStrategy and works to the JDO2 spec etc.
 - 
applyDefaultDiscriminatorValueWhenNotSpecifiedprotected void applyDefaultDiscriminatorValueWhenNotSpecified() 
 - 
validateUnmappedColumnsprotected void validateUnmappedColumns() Convenience method to validate the specified "unmapped" columns.- Throws:
- InvalidMetaDataException- if a column is specified without its name.
 
 - 
getSuperAbstractClassMetaDatapublic final AbstractClassMetaData getSuperAbstractClassMetaData() Accessor for the Meta-Data for the superclass of this class.- Returns:
- MetaData of the superclass
 
 - 
pkIsDatastoreAttributedpublic boolean pkIsDatastoreAttributed(StoreManager storeMgr) Convenience method to calculate and return if the pk has some component that is generated in the datastore.- Parameters:
- storeMgr- The storeManager
- Returns:
- Whether the PK is datastore generated
 
 - 
determineObjectIdClassprotected void determineObjectIdClass() Determine the object id class.- Throws:
- InvalidMetaDataException- if the class 0 or more that one primary key field and no- objectid-classhas been declared in the MetaData
- InvalidMetaDataException- if the- objectid-classhas not been set and the primary key field does not match a supported SingleFieldIdentity
- InvalidMetaDataException- if the identity type is APPLICATION but not primary key fields have been set
- InvalidMetaDataException- if the- objectid-classcannot be loaded by the- clr
 
 - 
validateObjectIdClassprotected void validateObjectIdClass(ClassLoaderResolver clr) Validate the objectid-class of this class.- Parameters:
- clr- ClassLoader resolver
 
 - 
populatepublic abstract void populate(ClassLoaderResolver clr, ClassLoader primary, MetaDataManager mmgr) Method to provide the details of the class being represented by this MetaData. This can be used to firstly provide defaults for attributes that aren't specified in the MetaData, and secondly to report any errors with attributes that have been specified that are inconsistent with the class being represented. This method must be invoked by subclasses during populate operations.- Parameters:
- clr- ClassLoaderResolver to use in loading any classes
- primary- the primary ClassLoader to use (or null)
- mmgr- MetaData manager
 
 - 
initialiseMemberPositionInformationprotected void initialiseMemberPositionInformation() Method to initialise all convenience information about member positions and what role each position performs.
 - 
getDiscriminatorMetaDataForTablepublic final DiscriminatorMetaData getDiscriminatorMetaDataForTable() Convenience method to find the discriminator MetaData defining the discrim for the same table as this class is using. Traverses up the inheritance tree to find the highest class that uses "subclass-table" that has discriminator metadata defined, and returns the MetaData.- Returns:
- DiscriminatorMetaData for the highest class in this tree using subclass-table
 
 - 
getDiscriminatorStrategyForTablepublic final DiscriminatorStrategy getDiscriminatorStrategyForTable() Convenience accessor for the discriminator strategy applying to this class. This is specified on the class managing the table if at all.- Returns:
- The discriminator strategy
 
 - 
getDiscriminatorMetaDatapublic final DiscriminatorMetaData getDiscriminatorMetaData() Convenience accessor for the discriminator metadata applying to this class. If specified on this class then returns that, otherwise goes up to the superclass (if present) until it finds a discriminator metadata specification.- Returns:
- The discriminator metadata
 
 - 
getDiscriminatorMetaDataRootpublic final DiscriminatorMetaData getDiscriminatorMetaDataRoot() Convenience method to return the "root" discriminator metadata definition (that defines the strategy, column etc). Useful when using "complete-table" inheritance, so we apply the root definition to the table for this class.- Returns:
- Discriminator metadata for the root
 
 - 
hasDiscriminatorStrategypublic final boolean hasDiscriminatorStrategy() Accessor for whether we have a discriminator defined for this class (may be in superclasses).- Returns:
- true if discriminatorStrategy is not null and not NONE
 
 - 
getDiscriminatorStrategypublic final DiscriminatorStrategy getDiscriminatorStrategy() Method to return the discriminator strategy being used by this class. Returns the strategy defined on this class (if any), otherwise goes up to the superclass etc until it finds a defined strategy.- Returns:
- The discriminator strategy
 
 - 
getDiscriminatorColumnNamepublic String getDiscriminatorColumnName() Return the name of the discriminator column if defined in metadata. If not provided directly for this class, goes up to the superclass to find it.- Returns:
- The column name for the discriminator
 
 - 
getDiscriminatorColumnMetaDatapublic ColumnMetaData getDiscriminatorColumnMetaData() Return the metadata for the discriminator column if defined in metadata. If not provided directly for this class, goes up to the superclass to find it.- Returns:
- The column metadata for the discriminator
 
 - 
getDiscriminatorValuepublic Object getDiscriminatorValue() Method returning the discriminator value to apply to an instance of this class. If using "class-name" then returns the class name, and if using the "entity-name" returns the entity name, otherwise if using "value-map" returns the value specified directly against this class metadata. The returned value is a String unless the user defined the column as holding integer-based values, in which case a Long is returned- Returns:
- The discriminator value
 
 - 
getIdentityTypepublic IdentityType getIdentityType() 
 - 
setIdentityTypepublic void setIdentityType(IdentityType type) 
 - 
getNamepublic String getName() Accessor for the simple class name (without package name).- Returns:
- class name
 
 - 
getFullClassNamepublic String getFullClassName() Accessor for the full class name including any package name.- Returns:
- full class name.
 
 - 
getObjectidClasspublic String getObjectidClass() 
 - 
setObjectIdClasspublic AbstractClassMetaData setObjectIdClass(String objectidClass) 
 - 
getEntityNamepublic String getEntityName() 
 - 
setEntityNamepublic AbstractClassMetaData setEntityName(String name) 
 - 
getCatalogpublic String getCatalog() 
 - 
setCatalogpublic AbstractClassMetaData setCatalog(String catalog) 
 - 
getSchemapublic String getSchema() 
 - 
setSchemapublic AbstractClassMetaData setSchema(String schema) 
 - 
getTablepublic String getTable() 
 - 
setTablepublic AbstractClassMetaData setTable(String table) 
 - 
isRequiresExtentpublic boolean isRequiresExtent() 
 - 
setRequiresExtentpublic AbstractClassMetaData setRequiresExtent(boolean flag) 
 - 
setRequiresExtentpublic AbstractClassMetaData setRequiresExtent(String flag) 
 - 
isDetachablepublic boolean isDetachable() 
 - 
setDetachablepublic AbstractClassMetaData setDetachable(boolean flag) 
 - 
setDetachablepublic AbstractClassMetaData setDetachable(String flag) 
 - 
isCacheablepublic Boolean isCacheable() 
 - 
setCacheablepublic AbstractClassMetaData setCacheable(boolean cache) 
 - 
setCacheablepublic AbstractClassMetaData setCacheable(String cache) 
 - 
isEmbeddedOnlypublic boolean isEmbeddedOnly() 
 - 
setEmbeddedOnlypublic AbstractClassMetaData setEmbeddedOnly(boolean flag) 
 - 
setEmbeddedOnlypublic AbstractClassMetaData setEmbeddedOnly(String flag) 
 - 
getPackageMetaDatapublic PackageMetaData getPackageMetaData() 
 - 
getPackageNamepublic String getPackageName() 
 - 
getPersistenceModifierpublic ClassPersistenceModifier getPersistenceModifier() 
 - 
setPersistenceModifierpublic AbstractClassMetaData setPersistenceModifier(ClassPersistenceModifier modifier) 
 - 
getPersistableSuperclasspublic String getPersistableSuperclass() 
 - 
usesSingleFieldIdentityClasspublic boolean usesSingleFieldIdentityClass() Whether this persistable class uses SingleFieldIdentity- Returns:
- true if using SingleFieldIdentity as objectid class
 
 - 
isSameOrAncestorOfpublic boolean isSameOrAncestorOf(AbstractClassMetaData cmd) Check if the argument cmd is the same as this or a descedent.- Parameters:
- cmd- the AbstractClassMetaData to be verify if this is an ancestor
- Returns:
- true if the argument is a child or same as this
 
 - 
getPrimaryKeyMemberNamespublic String[] getPrimaryKeyMemberNames() Accessor for the names of the primary key fields/properties. Only valid after being populated. Provided as a convenience where we need to get the names of the PK members but cant wait til initialisation.- Returns:
- names of the PK fields/properties
 
 - 
hasMemberpublic boolean hasMember(String memberName) Method to check if a member exists in this classes definition. Will include any superclasses in the check.- Parameters:
- memberName- Name of member
- Returns:
- return true if exists.
 
 - 
getNoOfMemberspublic int getNoOfMembers() Accessor for the number of members defined for this class (including overrides). This is the total number of members (inc static, final etc) in this class- Returns:
- no of fields/properties.
 
 - 
getMetaDataForMemberpublic AbstractMemberMetaData getMetaDataForMember(String name) Accessor for the Meta-Data for a member. Include superclasses.- Parameters:
- name- the name of the member
- Returns:
- Meta-Data for the member
 
 - 
getNoOfManagedMemberspublic int getNoOfManagedMembers() Accessor for the number of managed members (this class only).- Returns:
- no of managed members in this class
 
 - 
getManagedMemberspublic AbstractMemberMetaData[] getManagedMembers() Accessor for the managed fields/properties in this class (not including superclass, but including overridden).- Returns:
- MetaData for the managed fields/properties in this class
 
 - 
getOverriddenMemberspublic AbstractMemberMetaData[] getOverriddenMembers() Accessor for the overridden fields/properties in this class.- Returns:
- The overridden fields/properties in this class
 
 - 
getOverriddenMemberpublic AbstractMemberMetaData getOverriddenMember(String name) Accessor for an overridden field/property with the specified name.- Parameters:
- name- Name of the field/property
- Returns:
- The MetaData for the field/property
 
 - 
getMemberBeingOverriddenprotected AbstractMemberMetaData getMemberBeingOverridden(String name) Convenience method that navigates up a MetaData inheritance tree until it finds the base member definition for the specified name.- Parameters:
- name- Name of the member we require
- Returns:
- The metadata for the member
 
 - 
getNoOfInheritedManagedMemberspublic int getNoOfInheritedManagedMembers() Accessor for the number of inherited managed members in superclasses.- Returns:
- No of inherited managed members in superclasses.
 
 - 
getMemberCountpublic int getMemberCount() Accessor for the number of managed members from this class plus inherited classes.- Returns:
- The number of managed members from this class plus inherited classes.
 
 - 
getMetaDataForMemberAtRelativePositionpublic AbstractMemberMetaData getMetaDataForMemberAtRelativePosition(int index) Accessor for the metadata of a member. Does not include superclasses. In general this should never be used; always use "getMetaDataForManagedMemberAtAbsolutePosition".- Parameters:
- index- field index relative to this class only starting from 0
- Returns:
- Meta-Data for the member
 
 - 
getMetaDataForManagedMemberAtRelativePositionpublic AbstractMemberMetaData getMetaDataForManagedMemberAtRelativePosition(int position) Accessor for MetaData for a managed member in this class. The position is relative to the first member in this class (i.e ignores superclasses).- Parameters:
- position- The position of the managed field. 0 = first in the class
- Returns:
- The managed member at that position
 
 - 
getMetaDataForManagedMemberAtAbsolutePositionpublic AbstractMemberMetaData getMetaDataForManagedMemberAtAbsolutePosition(int position) Accessor for a managed member including superclass members. Allows for overriding of superclass members in this class and superclasses.- Parameters:
- position- The position of the managed member including the superclass. Fields are numbered from 0 in the root persistable superclass.
- Returns:
- The managed member at this "absolute" position.
 
 - 
getMetaDataForManagedMemberAtAbsolutePositionInternalprotected AbstractMemberMetaData getMetaDataForManagedMemberAtAbsolutePositionInternal(int abs_position) Internal method to get the field/property for an absolute field number. If the field for that absolute field position is overridden by a field in this class then this field/property will be returned.- Parameters:
- abs_position- The position of the managed field including the superclass. Fields are numbered from 0 in the root superclass.
- Returns:
- The managed field at this "absolute" position.
 
 - 
getRelativePositionOfMemberpublic int getRelativePositionOfMember(String memberName) Accessor for the (relative) position of the field/property with the specified name. The returned position is relative to this class only- Parameters:
- memberName- Name of the member
- Returns:
- Relative position of the member in this class
 
 - 
getAbsolutePositionOfMemberpublic int getAbsolutePositionOfMember(String memberName) Accessor for the absolute position of the field/property with the specified name. The absolute position has origin in the root persistable superclass, starting at 0.- Parameters:
- memberName- Name of the member
- Returns:
- Absolute position of the member
 
 - 
getNoOfPrimaryKeyMemberspublic int getNoOfPrimaryKeyMembers() Accessor for the number of primary key fields/properties.- Returns:
- no of primary key fields/properties
 
 - 
getAllMemberPositionspublic int[] getAllMemberPositions() Accessor for all field/property positions. These are absolute numbers and include superclasses and are really just 0, 1, 2, ... n.- Returns:
- The positions of all (managed) fields/properties.
 
 - 
getPKMemberPositionspublic int[] getPKMemberPositions() Accessor for the field numbers of the primary key fields/properties. These are absolute numbers (including superclasses).- Returns:
- The positions of the primary key fields/properties.
 
 - 
getNonPKMemberPositionspublic int[] getNonPKMemberPositions() Accessor for the positions of the non primary key fields/properties (inc superclass fields).- Returns:
- The member positions
 
 - 
getNonPKMemberFlagspublic boolean[] getNonPKMemberFlags() Accessor for the flags of the non primary key fields/properties (inc superclass members).- Returns:
- The flags whether the field/property is non primary key
 
 - 
getValueGenerationMemberPositionspublic int[] getValueGenerationMemberPositions() Accessor for the member positions which require value generation processing (non-null strategy).- Returns:
- The member positions that will have a value generated.
 
 - 
getCreateTimestampMemberPositionpublic int getCreateTimestampMemberPosition() 
 - 
getUpdateTimestampMemberPositionpublic int getUpdateTimestampMemberPosition() 
 - 
getCreateUserMemberPositionpublic int getCreateUserMemberPosition() 
 - 
getUpdateUserMemberPositionpublic int getUpdateUserMemberPosition() 
 - 
getDFGMemberPositionspublic int[] getDFGMemberPositions() Accessor for the absolute positions of the default fetch group fields/properties (inc superclasses).- Returns:
- The positions of the DFG fields/properties (inc superclasses).
 
 - 
getDFGMemberFlagspublic boolean[] getDFGMemberFlags() Accessor for the flags of the DFG fields/properties (inc superclass).- Returns:
- The flags whether the field/property is in the DFG
 
 - 
getBasicMemberPositionspublic int[] getBasicMemberPositions(ClassLoaderResolver clr) Accessor for the absolute positions of fields/properties that are considered basic. This category includes members of all basic (primitive and immutable object class) types as defined in section 6.4 of the specification, including String, Date and its jdbc subtypes, Locale, Currency, and Enum types. Includes all inherited multivalued positions. WARNING : this includes transient fields. DO NOT USE as a way of getting the persistent fields in the class.- Parameters:
- clr- ClassLoader resolver
- Returns:
- The absolute positions
 
 - 
getMultivaluedMemberPositionspublic int[] getMultivaluedMemberPositions() Accessor for the absolute positions of fields/properties that are considered multi-valued This category includes members of all multi-valued types, including Collection, array, and Map types of basic and relationship types. Includes all inherited multivalued positions.- Returns:
- The absolute positions
 
 - 
getSCOMutableMemberPositionspublic int[] getSCOMutableMemberPositions() Accessor for the absolute positions of the second class mutable fields/properties.- Returns:
- The field numbers of the second class mutable fields (inc superclasses).
 
 - 
getSCONonContainerMemberPositionspublic int[] getSCONonContainerMemberPositions() Accessor for the absolute positions of all SCO fields/properties that are NOT containers (e.g Dates, Points, etc)- Returns:
- Field numbers of all SCO non-container fields/properties
 
 - 
getSCOMutableMemberFlagspublic boolean[] getSCOMutableMemberFlags() Accessor for the flags of the SCO mutable fields (inc superclass fields).- Returns:
- The flags whether the field is second class mutable
 
 - 
getSCOContainerMemberFlagspublic boolean[] getSCOContainerMemberFlags() Accessor for the flags of whether members are SCO "containers" (Collection/Map/array).- Returns:
- The array of SCO container flags
 
 - 
hasRelationspublic boolean hasRelations(ClassLoaderResolver clr) Convenience method to return if the class has relations to other objects. Includes superclasses.- Parameters:
- clr- ClassLoader resolver
- Returns:
- Whether the class has any relations (that it knows about)
 
 - 
getNonRelationMemberPositionspublic int[] getNonRelationMemberPositions(ClassLoaderResolver clr) 
 - 
getRelationMemberPositionspublic int[] getRelationMemberPositions(ClassLoaderResolver clr) Convenience method to return the absolute positions of all fields/properties that have relations.- Parameters:
- clr- ClassLoader resolver
- Returns:
- The absolute positions of all fields/properties that have relations
 
 - 
getBidirectionalRelationMemberPositionspublic int[] getBidirectionalRelationMemberPositions(ClassLoaderResolver clr) Convenience method to return the absolute positions of fields/properties that have bidirectional relations.- Parameters:
- clr- ClassLoader resolver
- Returns:
- Absolute positions of bidirectional relation fields/properties
 
 - 
setAccessViaFieldpublic void setAccessViaField(boolean flag) 
 - 
getAccessViaFieldpublic Boolean getAccessViaField() 
 - 
setMappedSuperclasspublic void setMappedSuperclass(boolean mapped) 
 - 
isMappedSuperclasspublic boolean isMappedSuperclass() 
 - 
setSerializeReadpublic void setSerializeRead(boolean serialise) 
 - 
isSerializeReadpublic boolean isSerializeRead() 
 - 
setMetaDataCompletepublic void setMetaDataComplete() Method to set that this class is "metadata complete" (see JPA spec). Means that any annotations will be ignored.
 - 
isMetaDataCompletepublic boolean isMetaDataComplete() Accessor for whether this class is fully specified by this metadata and that any annotations should be ignored.- Returns:
- Whether we should ignore any annotations
 
 - 
addQuerypublic void addQuery(QueryMetaData qmd) Method to add a named query to this class. Rejects the addition of duplicate named queries.- Parameters:
- qmd- Meta-Data for the query.
 
 - 
getNoOfQueriespublic int getNoOfQueries() Accessor for the number of named queries.- Returns:
- no of named queries
 
 - 
getQueriespublic QueryMetaData[] getQueries() Accessor for the metadata of the named queries.- Returns:
- Meta-Data for the named queries.
 
 - 
newQueryMetaDatapublic QueryMetaData newQueryMetaData(String queryName) Method to create a new QueryMetadata, add it to the registered queries and return it.- Parameters:
- queryName- Name of the query
- Returns:
- The Query metadata
 
 - 
addStoredProcQuerypublic void addStoredProcQuery(StoredProcQueryMetaData qmd) Method to add a named stored proc query to this class. Rejects the addition of duplicate named queries.- Parameters:
- qmd- Meta-Data for the query.
 
 - 
getNoOfStoredProcQueriespublic int getNoOfStoredProcQueries() Accessor for the number of named stored proc queries.- Returns:
- no of named stored proc queries
 
 - 
getStoredProcQueriespublic StoredProcQueryMetaData[] getStoredProcQueries() Accessor for the metadata of the named stored proc queries.- Returns:
- Meta-Data for the named stored proc queries.
 
 - 
newStoredProcQueryMetaDatapublic StoredProcQueryMetaData newStoredProcQueryMetaData(String queryName) Method to create a new StoredProcQueryMetadata, add it to the registered queries and return it.- Parameters:
- queryName- Name of the proc query
- Returns:
- The Query metadata
 
 - 
addQueryResultMetaDatapublic void addQueryResultMetaData(QueryResultMetaData resultMetaData) Method to register a query-result MetaData.- Parameters:
- resultMetaData- Query-Result MetaData to register
 
 - 
getQueryResultMetaDatapublic QueryResultMetaData[] getQueryResultMetaData() Get the query result MetaData registered for this class.- Returns:
- Query Result MetaData defined for this class
 
 - 
addIndexpublic void addIndex(IndexMetaData idxmd) Method to add an index to this class.- Parameters:
- idxmd- Meta-Data for the index.
 
 - 
getIndexMetaDatapublic final List<IndexMetaData> getIndexMetaData() 
 - 
newIndexMetaDatapublic IndexMetaData newIndexMetaData() Method to create a new index metadata, add it, and return it.- Returns:
- The index metadata
 
 - 
addForeignKeypublic void addForeignKey(ForeignKeyMetaData fkmd) Method to add an foreign-key to this class.- Parameters:
- fkmd- Meta-Data for the foreign-key.
 
 - 
getForeignKeyMetaDatapublic final List<ForeignKeyMetaData> getForeignKeyMetaData() 
 - 
newForeignKeyMetaDatapublic ForeignKeyMetaData newForeignKeyMetaData() Method to create a new FK metadata, add it, and return it.- Returns:
- The FK metadata
 
 - 
addUniqueConstraintpublic void addUniqueConstraint(UniqueMetaData unimd) Method to add a unique constraint to this class.- Parameters:
- unimd- Meta-Data for the unique constraint.
 
 - 
getUniqueMetaDatapublic final List<UniqueMetaData> getUniqueMetaData() 
 - 
newUniqueMetaDatapublic UniqueMetaData newUniqueMetaData() Method to create a new unique metadata, add it, and return it.- Returns:
- The unique metadata
 
 - 
addUnmappedColumnpublic final void addUnmappedColumn(ColumnMetaData colmd) Method to add an unmapped column.- Parameters:
- colmd- The metadata for the unmapped column
 
 - 
getUnmappedColumnspublic final List<ColumnMetaData> getUnmappedColumns() Accessor for the unmapped columns required for the datastore table.- Returns:
- The list of unmapped columns
 
 - 
newUnmappedColumnMetaDatapublic ColumnMetaData newUnmappedColumnMetaData() 
 - 
newFieldMetaDatapublic FieldMetaData newFieldMetaData(String fieldName) Method to create a new field metadata, add it, and return it.- Parameters:
- fieldName- Name of the field
- Returns:
- The metadata
 
 - 
newPropertyMetaDatapublic PropertyMetaData newPropertyMetaData(String propName) Method to create a new property metadata, add it, and return it.- Parameters:
- propName- Name of the property
- Returns:
- The metadata
 
 - 
addMemberpublic void addMember(AbstractMemberMetaData mmd) Method to add a field/property to this interface. Rejects the addition of duplicate named fields/properties.- Parameters:
- mmd- Field/Property MetaData
 
 - 
addFetchGrouppublic void addFetchGroup(FetchGroupMetaData fgmd) Method to add a fetch-group to this class.- Parameters:
- fgmd- Meta-Data for the fetch-group.
 
 - 
newFetchGroupMetaDatapublic FetchGroupMetaData newFetchGroupMetaData(String name) Method to create a new fetchgroup metadata, add it, and return it.- Parameters:
- name- Name of the group
- Returns:
- The fetchgroup metadata
 
 - 
getFetchGroupMetaDatapublic Set<FetchGroupMetaData> getFetchGroupMetaData(Collection<String> groupNames) Accessor for fetch group metadata for the specified groups (if present). The returned metadata is what is defined for this class that matches any of the names in the input set.- Parameters:
- groupNames- Names of the fetch groups
- Returns:
- MetaData for the groups
 
 - 
getFetchGroupMetaDatapublic FetchGroupMetaData getFetchGroupMetaData(String groupname) Accessor for the fetch group metadata for the group specified.- Parameters:
- groupname- Name of the fetch group
- Returns:
- MetaData for this group
 
 - 
getFetchGroupMetaDatapublic final Set<FetchGroupMetaData> getFetchGroupMetaData() Accessor for all MetaData defined for fetch groups for this class. This doesn't include superclasses.- Returns:
- Returns the Fetch Group metadata registered on this class
 
 - 
hasFetchGroupWithPostLoadpublic final boolean hasFetchGroupWithPostLoad() Whether this class or any super class has any fetch group definition withFetchGroupMetaData.getPostLoad()==true.- Returns:
- Whether there is a fetch-group definition with post-load
 
 - 
addJoinpublic void addJoin(JoinMetaData jnmd) Method to add a join to this class. Rejects the addition of duplicate named fields.- Parameters:
- jnmd- Meta-Data for the join.
 
 - 
getJoinMetaDatapublic final List<JoinMetaData> getJoinMetaData() 
 - 
newJoinMetaDatapublic JoinMetaData newJoinMetaData() Method to create a new join metadata, add it, and return it.- Returns:
- The join metadata
 
 - 
addListenerpublic void addListener(EventListenerMetaData listener) Add a listener class name- Parameters:
- listener- the listener metadata. Duplicated classes are ignored
 
 - 
getListenerForClasspublic EventListenerMetaData getListenerForClass(String className) Accessor for the EventListener info for an EventListener class name- Parameters:
- className- Name of the event listener class
- Returns:
- EventListener info for this class (or null if the class isnt an EventListener)
 
 - 
getListenerspublic List<EventListenerMetaData> getListeners() Get the event listeners- Returns:
- the event listeners
 
 - 
excludeSuperClassListenerspublic void excludeSuperClassListeners() Toogle exclude super class listeners
 - 
isExcludeSuperClassListenerspublic boolean isExcludeSuperClassListeners() Whether super classes listeners are not going to be invoked- Returns:
- true if super class listeners are not invoked
 
 - 
excludeDefaultListenerspublic void excludeDefaultListeners() Method to exclude default listeners.
 - 
isExcludeDefaultListenerspublic boolean isExcludeDefaultListeners() Whether default listeners are not going to be invoked- Returns:
- true if default listeners are not invoked
 
 - 
setVersionMetaDatapublic final void setVersionMetaData(VersionMetaData versionMetaData) Mutator for the Version MetaData.- Parameters:
- versionMetaData- The versionMetaData to set.
 
 - 
getVersionMetaDatapublic final VersionMetaData getVersionMetaData() Accessor for Version MetaData for this class specifically. Note that this just returns what this class had defined, and if this has no version info then you really need what the superclass has (if there is one). Consider using getVersionMetaDataForClass().- Returns:
- Returns the versionMetaData.
 
 - 
getVersionMetaDataForClasspublic final VersionMetaData getVersionMetaDataForClass() Convenience accessor for the version metadata applying to this class. Differs from getVersionMetaData by searching superclasses.- Returns:
- The version metadata
 
 - 
isVersionedpublic final boolean isVersioned() Returns whether objects of this type are versioned. A return of true means that either this class has version information, or a superclass does, and that the version information is required to be stored.- Returns:
- Whether it is versioned.
 
 - 
getVersionMetaDataForTablepublic final VersionMetaData getVersionMetaDataForTable() Convenience method to find the version MetaData defining versioning for the same 'table' as this class is using. Traverses up the inheritance tree to find the highest class that uses "subclass-table" that has version metadata defined, or the class that owns the 'table' where this class uses "superclass-table", and returns the MetaData.- Returns:
- Version MetaData for the highest class in this tree using subclass-table
 
 - 
newVersionMetaDatapublic VersionMetaData newVersionMetaData() Method to create a new version metadata, set to use it, and return it.- Returns:
- The version metadata
 
 - 
setDatastoreIdentityMetaDatapublic final void setDatastoreIdentityMetaData(DatastoreIdentityMetaData identityMetaData) Mutator for the datastore identity MetaData.- Parameters:
- identityMetaData- The datastore identity MetaData to set.
 
 - 
getDatastoreIdentityMetaDatapublic final DatastoreIdentityMetaData getDatastoreIdentityMetaData() Accessor for datastore identity MetaData- Returns:
- Returns the datastore identity MetaData.
 
 - 
getBaseDatastoreIdentityMetaDatapublic final DatastoreIdentityMetaData getBaseDatastoreIdentityMetaData() Convenience method to return the root identity metadata for this inheritance tree.- Returns:
- DatastoreIdentityMetaData at the base
 
 - 
newDatastoreIdentityMetaDatapublic DatastoreIdentityMetaData newDatastoreIdentityMetaData() Method to create a new datastore identity metadata, set to use it, and return it.- Returns:
- The datastore identity metadata
 
 - 
getMultitenancyMetaDatapublic final MultitenancyMetaData getMultitenancyMetaData() 
 - 
setMultitenancyMetaDatapublic final void setMultitenancyMetaData(MultitenancyMetaData mtmd) 
 - 
newMultitenancyMetaDatapublic MultitenancyMetaData newMultitenancyMetaData() 
 - 
getSoftDeleteMetaDatapublic final SoftDeleteMetaData getSoftDeleteMetaData() 
 - 
setSoftDeleteMetaDatapublic final void setSoftDeleteMetaData(SoftDeleteMetaData sdmd) 
 - 
newSoftDeleteMetaDatapublic SoftDeleteMetaData newSoftDeleteMetaData() 
 - 
isSoftDeletepublic boolean isSoftDelete() 
 - 
setInheritanceMetaDatapublic final void setInheritanceMetaData(InheritanceMetaData inheritanceMetaData) Mutator for the inheritance MetaData.- Parameters:
- inheritanceMetaData- The inheritanceMetaData to set.
 
 - 
getInheritanceMetaDatapublic final InheritanceMetaData getInheritanceMetaData() Accessor for inheritanceMetaData- Returns:
- Returns the inheritanceMetaData.
 
 - 
newInheritanceMetaDatapublic InheritanceMetaData newInheritanceMetaData() Method to create a new inheritance metadata, set to use it, and return it.- Returns:
- The inheritance metadata
 
 - 
setPrimaryKeyMetaDatapublic final void setPrimaryKeyMetaData(PrimaryKeyMetaData primaryKeyMetaData) Mutator for the PrimaryKey MetaData.- Parameters:
- primaryKeyMetaData- The PrimaryKey MetaData to set.
 
 - 
getPrimaryKeyMetaDatapublic final PrimaryKeyMetaData getPrimaryKeyMetaData() Accessor for primaryKeyMetaData- Returns:
- Returns the primaryKey MetaData.
 
 - 
newPrimaryKeyMetaDatapublic PrimaryKeyMetaData newPrimaryKeyMetaData() Method to create a new primary key metadata, set to use it, and return it.- Returns:
- The primary key metadata
 
 - 
checkForCircularViewReferencesprotected static void checkForCircularViewReferences(Map<String,Set<String>> viewReferences, String referencerName, String referenceeName, List<String> referenceChain) Check for any circular view references between referencer and referencee. If one is found, throw a NucleusUserException with the chain of references.- Parameters:
- viewReferences- The Map of view references to check.
- referencerName- Name of the class that has the reference.
- referenceeName- Name of the class that is being referenced.
- referenceChain- The List of class names that have been referenced
- Throws:
- NucleusUserException- If a circular reference is found in the view definitions.
 
 
- 
 
-