Adding or Removing Foreign Keys
A foreign key is a field in one database table that references the primary key in another table. The foreign key is defined as a constraint on the related column in the database table.
With the foreign key constraint in place, the field must either be empty, or the value must point to an existing value for the primary key in the referenced table. For example, the SiteUID field on a shift is a foreign key that references the UID of a site. As a result, the value for the SiteUID on a shift must either be empty or match an existing UID value for a site.
The foreign key constraint also prevents the deletion of rows from the database table that are referenced by foreign key fields. For example, if a shift has a SiteUID value of 5, then because of the foreign key constraint on the SiteUID field references the UID on a site, the site with the UID value of 5 cannot be deleted.
Adding a Foreign Key
To add a foreign key to an existing database table:
1. Create a new building block that extends from the PTC building block which contains the manager for the entity that is related to the database table. These managers are specified in the DefaultGlobalManagerConfiguration table on the Configuration page of the PTC.Base.Manager. For example, to add a foreign key to a job order, navigate to the PTC.JobOrderImpl.Manager Thing.
2. Navigate to the manager Thing for your new building block.
3. Under Services, override the GetDBInfo service for the entity to which you are adding the foreign key. For example, to add a foreign key to the database table for job orders, override the GetDBInfo service on the PTC.JobOrderImpl.Manager Thing.
4. In the script editor, scroll down to the entry for the Data Shape to which you want to add the foreign key.
5. Add a foreignKeys array for the Data Shape, with the following properties:
◦ identifier—The name of the entity in the database. If not specified, then the system automatically generates the value in the format <table_name>_<column_name>_fk. If specified, then the value must be unique both for specified values and for any automatically generated values. The maximum length for the value is the maximum length allowed by the database for identifiers.
◦ name—Name of the field on the current Data Shape to be a foreign key. The base type of the foreign key field should match the base type of the referenced field. For example, if the referenced field has the STRING base type, the foreign key field should also have a STRING base type.
◦ referenceDataShapeName—The Data Shape of the referenced database table.
◦ referenceFieldName—The name of the field containing the value being referenced.
◦ onDelete—The impact on instances of the current Data Shape when instances of the referenced Data Shape are deleted.
◦ deleteReference—The impact on instances of the referenced Data Shape when instances of the current Data Shape are deleted.
6. Click Save to save the changes to the service.
7. Navigate to the PTC.DBConnection.Manager Thing.
Removing a Foreign Key
To remove a foreign key:
1. Create a new building block that extends from the PTC building block which contains the manager for the entity that is related to the database table. These managers are specified in the DefaultGlobalManagerConfiguration table on the Configuration page of the PTC.Base.Manager. For example, to remove a foreign key to a job order, navigate to the PTC.JobOrderImpl.Manager Thing.
2. Navigate to the database Thing configured for your system, for example, PTC.DBConnection.SQLThingDatabase.
3. Under Services, execute the RemoveForeignKey service with the following inputs:
◦ dataShapeName—The Data Shape for the database table from which you are removing the foreign key constraint.
◦ fieldName—The field on the Data Shape on which you are removing the foreign key constraint.
◦ dbInfo—The JSON description of the foreign key to be removed. The same identifier (if any), name, referenceDataShapeName, and refereceFieldName information that is specified in the GetDBInfo service where the foreign key is defined must be provided. Any onDelete or deleteReference values are ignored by the service if they are included.
4. Click Execute.
5. On the manager Thing of the building block you created in step 1, navigate to the
GetDBInfo service where the foreign key is defined, and remove the foreign key definition from the services. If this is not removed, then the foreign key is added back to the database the next time the
synchronization services are run.
For example, to remove a foreign key constraint with no identifier specified from a field named WorkDefinitionUID on the MyObject Data Shape, specify the following for the input parameters:
• dataShapeName—MyObject
• fieldName—WorkDefinitionUID
• dbInfo—
{
"name":"WorkDefinitionUID",
"referenceDataShapeName":"PTC.SCA.SCO.WorkDefinition",
"referenceFieldName":"UID"
}