Package com.sas.metadata.remote
Interface ForeignKey
- All Superinterfaces:
CMetadata,Key,MdObjectBase,MdObjectBaseUtil,MdObjectBaseXML,Remote,Root,SecondaryType
Represents the fact that a table contains a foreign key to another table.
Example: create a ForeignKey with name "ForeignKey_Object", in repository "AAAAAAAA".
Attributes of ForeignKey are:
Associations of ForeignKey are:
Usage
To create an instance of this ForeignKey, use thefactory
create methods. Example: create a ForeignKey with name "ForeignKey_Object", in repository "AAAAAAAA".
// create a store to contain your objects for this change. If you do not have an existing object // or store to use. You may obtain the store from another object by using Object.getObjectStore(). MdFactory factory; //where "factory" is a valid MdFactory instance MdObjectStore objectStore = factory.createObjectStore(); ForeignKey myObject = (ForeignKey) factory.createComplexMetadataObject(objectStore, "ForeignKey_Object", MetadataObjects.FOREIGNKEY, "AAAAAAAA"); myObject.updateMetadataAll(); // Write object to server objectStore.dispose(); // dispose of the object store if it is no longer needed
Behavior
- Attributes and associations for this object can be retrieved by using the methods in
MdOMIUtil. - When changes are made to the object, either by setting an attribute or adding objects to a particular association,
they can be persisted to the metadata server with the
updateMetadataAllmethod. - If an object needs to be deleted, the
deletemethod can be used. This will flag the object as being deleted on the client, and will require an update call to persist the change to the server.
Dependencies
This class depends on objects being contained in an MdObjectStore. Object stores should be disposed of when they are no longer needed as this will help clean up memory. Disposing an object store will dispose of all objects contained within that store.- Since:
- 9.0
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final StringConstant used for the name of the KeyAssociations association.static final StringConstant used for the name of the PartnerUniqueKey association.static final StringConstant used for the name of the Table association.Fields inherited from interface com.sas.metadata.remote.Key
ASSOCIATION_DISPLAYCOLUMNS_NAME, ASSOCIATION_KEYEDCOLUMNS_NAMEFields inherited from interface com.sas.metadata.remote.MdObjectBase
ATTRIBUTE_DESC_NAME, ATTRIBUTE_ID_NAME, ATTRIBUTE_METADATACREATED_NAME, ATTRIBUTE_METADATAUPDATED_NAME, ATTRIBUTE_NAME_NAMEFields inherited from interface com.sas.metadata.remote.Root
ASSOCIATION_ACCESSCONTROLS_NAME, ASSOCIATION_CHANGES_NAME, ASSOCIATION_CUSTOMASSOCIATIONS_NAME, ASSOCIATION_DOCUMENTS_NAME, ASSOCIATION_EXTENSIONS_NAME, ASSOCIATION_EXTERNALIDENTITIES_NAME, ASSOCIATION_GROUPS_NAME, ASSOCIATION_IMPLEMENTORS_NAME, ASSOCIATION_KEYWORDS_NAME, ASSOCIATION_LOCALIZEDATTRIBUTES_NAME, ASSOCIATION_NOTES_NAME, ASSOCIATION_PRIMARYPROPERTYGROUP_NAME, ASSOCIATION_PROMPTS_NAME, ASSOCIATION_PROPERTIES_NAME, ASSOCIATION_PROPERTYSETS_NAME, ASSOCIATION_REFERENCEDOBJECTS_NAME, ASSOCIATION_RESPONSIBLEPARTIES_NAME, ASSOCIATION_SOURCETRANSFORMATIONS_NAME, ASSOCIATION_SPECSOURCETRANSFORMATIONS_NAME, ASSOCIATION_SPECTARGETTRANSFORMATIONS_NAME, ASSOCIATION_TARGETTRANSFORMATIONS_NAME, ASSOCIATION_TIMESTAMPS_NAME, ASSOCIATION_TREES_NAME, ASSOCIATION_TSOBJECTNAMESPACE_NAME, ASSOCIATION_USEDBYPROTOTYPES_NAME, ASSOCIATION_USINGPROTOTYPE_NAME, ASSOCIATION_VARIABLES_NAME, ATTRIBUTE_CHANGESTATE_NAME, ATTRIBUTE_LOCKEDBY_NAME, ATTRIBUTE_USAGEVERSION_NAME -
Method Summary
Modifier and TypeMethodDescriptionGets the AssociationList ofKeyAssociationsgetKeyAssociations(boolean fGoToServer) Gets the Associationlist ofKeyAssociationsGets theUniqueKeyforPartnerUniqueKeyGets the AssociationList ofPartnerUniqueKeysgetPartnerUniqueKeys(boolean fGoToServer) Gets the Associationlist ofPartnerUniqueKeysgetTable()Gets theDataTableforTableGets the Association list ofTablesgetTables(boolean fGoToServer) Gets the Associationlist ofTablesvoid(S) Adds the Associated objects to the predObjects which are:
KeyAssociations
PartnerUniqueKeyvoid(S) This initializes the Required Objects(Roles) which are:
TablevoidSets theKeyAssociationslist to belist.voidsetKeyAssociations(AssociationList inObjects, int state) Sets the entire AssociationList to match the passed in Vector, sets the state of the AssociationListvoidsetPartnerUniqueKey(UniqueKey inObject) Sets thePartnerUniqueKeyslist 0th element to beinObject.voidSets thePartnerUniqueKeyslist to belist.voidsetPartnerUniqueKeys(AssociationList list, int state) Sets thePartnerUniqueKeyslist to belist.voidSets theTableslist 0th element to beinObject.voidsetTables(AssociationList list) Sets theTableslist to belist.voidsetTables(AssociationList list, int state) Sets theTableslist to belist.Methods inherited from interface com.sas.metadata.remote.Key
getDisplayColumns, getDisplayColumns, getKeyedColumns, getKeyedColumns, setDisplayColumns, setDisplayColumns, setKeyedColumns, setKeyedColumnsMethods inherited from interface com.sas.metadata.remote.MdObjectBase
addElementToChangeList, clearChangeList, getChangeList, getCMetadataType, getDesc, getDescMaxLength, getDescState, getFQID, getId, getIdState, getMetadataCreated, getMetadataCreatedState, getMetadataUpdated, getMetadataUpdatedState, getName, getNameMaxLength, getNameState, getObjectStore, getPredAssociations, getRepositoryID, getRequiredAssociations, getState, isAssociationRequired, isNewObject, isPredAssociation, removeElementFromChangeList, resetObject, resetState, resetStates, setCMetadataType, setDesc, setDesc, setDescState, setFQID, setFQID, setId, setId, setIdState, setMetadataCreated, setMetadataCreated, setMetadataCreatedState, setMetadataUpdated, setMetadataUpdated, setMetadataUpdatedState, setName, setName, setNameState, setObjectStore, setStateMethods inherited from interface com.sas.metadata.remote.MdObjectBaseUtil
addMdObjectListener, delete, dispose, fireMdObjectModified, getAssociatedObjects, getAssociatedObjects, getAssociatedObjects, getAssociationNames, getAssocs, getAssocsWA, getAttributeNames, getAttrs, getAttrsStates, getAuthorizationUtil, getChangeManagementState, getChgMgtExternalIdentityImportType, getClientSideOnlyObject, getMdObjectAssociation, getPopulatedAssocs, getUpdatedAttrs, getViewList, isCheckedOut, isLocked, objectModified, removeMdObjectListener, setAttrs, setChangeManagementTargetRepository, setChgMgtExternalIdentityImportType, setClientSideOnlyObject, setMdObjectAssociation, touch, updateAssnsIdsMethods inherited from interface com.sas.metadata.remote.MdObjectBaseXML
closeUpdateMetadataXML, createEmptyXML, createObjectRefreshXML, createObjectXML, createObjectXML, createUpdateAssociationXML, createUpdateAssociationXML, createUpdateSimpleXML, doCreateUpdateXML, getUpdateSimpleSubstring, updateMetadataAllMethods inherited from interface com.sas.metadata.remote.Root
getAccessControls, getAccessControls, getChanges, getChanges, getChangeState, getChangeStateMaxLength, getChangeStateState, getCustomAssociations, getCustomAssociations, getDocuments, getDocuments, getExtensions, getExtensions, getExternalIdentities, getExternalIdentities, getGroups, getGroups, getImplementors, getImplementors, getKeywords, getKeywords, getLocalizedAttributes, getLocalizedAttributes, getLockedBy, getLockedByMaxLength, getLockedByState, getNotes, getNotes, getPrimaryPropertyGroup, getPrimaryPropertyGroups, getPrimaryPropertyGroups, getPrompts, getPrompts, getProperties, getProperties, getPropertySets, getPropertySets, getReferencedObjects, getReferencedObjects, getResponsibleParties, getResponsibleParties, getSourceTransformations, getSourceTransformations, getSpecSourceTransformations, getSpecSourceTransformations, getSpecTargetTransformations, getSpecTargetTransformations, getTargetTransformations, getTargetTransformations, getTimestamps, getTimestamps, getTrees, getTrees, getTSObjectNamespace, getTSObjectNamespaces, getTSObjectNamespaces, getUsageVersion, getUsageVersionState, getUsedByPrototypes, getUsedByPrototypes, getUsingPrototype, getUsingPrototypes, getUsingPrototypes, getVariables, getVariables, setAccessControls, setAccessControls, setChanges, setChanges, setChangeState, setChangeState, setChangeStateState, setCustomAssociations, setCustomAssociations, setDocuments, setDocuments, setExtensions, setExtensions, setExternalIdentities, setExternalIdentities, setGroups, setGroups, setImplementors, setImplementors, setKeywords, setKeywords, setLocalizedAttributes, setLocalizedAttributes, setLockedBy, setLockedBy, setLockedByState, setNotes, setNotes, setPrimaryPropertyGroup, setPrimaryPropertyGroups, setPrimaryPropertyGroups, setPrompts, setPrompts, setProperties, setProperties, setPropertySets, setPropertySets, setReferencedObjects, setReferencedObjects, setResponsibleParties, setResponsibleParties, setSourceTransformations, setSourceTransformations, setSpecSourceTransformations, setSpecSourceTransformations, setSpecTargetTransformations, setSpecTargetTransformations, setTargetTransformations, setTargetTransformations, setTimestamps, setTimestamps, setTrees, setTrees, setTSObjectNamespace, setTSObjectNamespaces, setTSObjectNamespaces, setUsageVersion, setUsageVersion, setUsageVersion, setUsageVersion, setUsageVersionState, setUsedByPrototypes, setUsedByPrototypes, setUsingPrototype, setUsingPrototypes, setUsingPrototypes, setVariables, setVariables
-
Field Details
-
ASSOCIATION_KEYASSOCIATIONS_NAME
static final String ASSOCIATION_KEYASSOCIATIONS_NAMEConstant used for the name of the KeyAssociations association.KeyAssociations: The list of association objects that associate a column in this foreign key to a column in the unique key.
- See Also:
-
ASSOCIATION_PARTNERUNIQUEKEY_NAME
static final String ASSOCIATION_PARTNERUNIQUEKEY_NAMEConstant used for the name of the PartnerUniqueKey association.PartnerUniqueKey: The unique key associated with this foreign key.
- See Also:
-
ASSOCIATION_TABLE_NAME
static final String ASSOCIATION_TABLE_NAMEConstant used for the name of the Table association.Table: The table that contains this foreign key.
- See Also:
-
-
Method Details
-
initializeRequiredObjects
void initializeRequiredObjects() throws RemoteException(S) This initializes the Required Objects(Roles) which are:
Table- Specified by:
initializeRequiredObjectsin interfaceKey- Specified by:
initializeRequiredObjectsin interfaceMdObjectBaseUtil- Specified by:
initializeRequiredObjectsin interfaceRoot- Specified by:
initializeRequiredObjectsin interfaceSecondaryType- Throws:
RemoteException- If error connecting/communicating to/with remote object.
-
initializePredObjects
void initializePredObjects() throws RemoteException(S) Adds the Associated objects to the predObjects which are:
KeyAssociations
PartnerUniqueKey- Specified by:
initializePredObjectsin interfaceKey- Specified by:
initializePredObjectsin interfaceMdObjectBase- Specified by:
initializePredObjectsin interfaceRoot- Specified by:
initializePredObjectsin interfaceSecondaryType- Throws:
RemoteException- If error connecting/communicating to/with remote object.
-
getKeyAssociations
Gets the AssociationList ofKeyAssociations- Returns:
- Returns the AssociationList of
KeyAssociationswhich can be of type:
KeyAssociation - Throws:
RemoteException- If error connecting/communicating to/with remote object.MdException- If error getting/setting part of the object.
-
getPartnerUniqueKeys
Gets the AssociationList ofPartnerUniqueKeys- Returns:
- Returns the AssociationList of
PartnerUniqueKeyswhich can be of type:
UniqueKey - Throws:
RemoteException- If error connecting/communicating to/with remote object.MdException
-
getPartnerUniqueKey
Gets theUniqueKeyforPartnerUniqueKey- Returns:
- The
UniqueKey(nullif not set) ofPartnerUniqueKeywhich can be of type:
UniqueKey - Throws:
RemoteException- If error connecting/communicating to/with remote object.MdException- If error getting/setting part of the object.
-
getTables
Gets the Association list ofTables- Returns:
- The AssociationList of
Tableswhich can be of type:
DataTable
ExternalTable
RelationalTable
PhysicalTable
WorkTable
SecuredTable
QueryTable
JoinTable
TableCollection - Throws:
RemoteException- If error connecting/communicating to/with remote object.MdException- If error getting/setting part of the object.
-
getTable
Gets theDataTableforTable- Returns:
- The
DataTable(nullif not set ) ofTablewhich can be of type:
DataTable
ExternalTable
RelationalTable
PhysicalTable
WorkTable
SecuredTable
QueryTable
JoinTable
TableCollection - Throws:
RemoteException- If error connecting/communicating to/with remote object.MdException- If error getting/setting part of the object.
-
getKeyAssociations
Gets the Associationlist ofKeyAssociations- Parameters:
fGoToServer- boolean Get the value from the server.- Returns:
- Returns the AssociationList of
KeyAssociationswhich can be of type:
KeyAssociation - Throws:
RemoteException- If error connecting/communicating to/with remote object.MdException- If error getting/setting part of the object.
-
getPartnerUniqueKeys
Gets the Associationlist ofPartnerUniqueKeys- Parameters:
fGoToServer- boolean Get the value from the server.- Returns:
- Returns the AssociationList of
PartnerUniqueKeyswhich can be of type:
UniqueKey - Throws:
RemoteException- If error connecting/communicating to/with remote object.MdException- If error getting/setting part of the object.
-
getTables
Gets the Associationlist ofTables- Parameters:
fGoToServer- boolean Get the value from the server.- Returns:
- Returns the
Tableswhich can be of type:
DataTable
ExternalTable
RelationalTable
PhysicalTable
WorkTable
SecuredTable
QueryTable
JoinTable
TableCollection - Throws:
RemoteException- If error connecting/communicating to/with remote object.MdException- If error getting/setting part of the object.
-
setKeyAssociations
- Parameters:
list- AssociationList- Throws:
RemoteException- If error communicating with remote object.
-
setKeyAssociations
Sets the entire AssociationList to match the passed in Vector, sets the state of the AssociationList- Parameters:
inObjects- AssociationListstate- int- Throws:
RemoteException- If error communicating with remote object.
-
setPartnerUniqueKeys
- Parameters:
list- AssociationList- Throws:
RemoteException- If error communicating with remote object.
-
setPartnerUniqueKeys
- Parameters:
list- AssociationListstate- int- Throws:
RemoteException- If error communicating with remote object.
-
setPartnerUniqueKey
Sets thePartnerUniqueKeyslist 0th element to beinObject.- Parameters:
inObject- UniqueKey- Throws:
RemoteException- If error communicating with remote object.
-
setTables
Sets theTableslist to belist. Objects of which can be of type:
DataTable
ExternalTable
RelationalTable
PhysicalTable
WorkTable
SecuredTable
QueryTable
JoinTable
TableCollection- Parameters:
list- AssociationList- Throws:
RemoteException- If error communicating with remote object.
-
setTables
Sets theTableslist to belist. Objects of which can be of type:
DataTable
ExternalTable
RelationalTable
PhysicalTable
WorkTable
SecuredTable
QueryTable
JoinTable
TableCollection- Parameters:
list- AssociationListstate- int- Throws:
RemoteException- If error communicating with remote object.
-
setTable
Sets theTableslist 0th element to beinObject.- Parameters:
inObject- DataTable- Throws:
RemoteException- If error communicating with remote object.
-