Skip to main content
Understanding Object Relationships
Updated over a month ago

Overview

In Salesforce, objects are related to each other with the following relationships:

  • Lookup

  • Master-detail

  • Many-to-many

  • Indirect lookup

  • External lookup

  • Hierarchical

For detailed information about object relationships, see Object Relationships Overview - https://help.salesforce.com/articleView?id=sf.overview_of_custom_object_relationships.htm&type=5.

When users create records with these object relationships, the records may contain:

  • Blank lookup values, also known as orphan records,

  • Contain a reference to other child and parent records,

  • Include fields that reference other records on the same object.

Within a Data Template, you can select records, and the application automatically discovers the related parent and child records.

Child Record Levels

The section describes how selecting child records during Data Template creation works for the following example.

For example, a Project includes Project Team Members and a set of Deliverables. Each Project Team Member is a Team Member who has Resources. Each Team Member also has a Physical Location. In this scenario, the following objects are related to each other:

  • Project

  • Project Team Members

  • Deliverables

  • Resources

  • Physical Location

The following relationship diagram illustrates the object relationships.

Salesforce_Child_Records_Level_Diagram.png

The meaning of relationship levels for a Project record is as follows:

Relationship Level

Description

None

  • Includes Project record

  • Does not include Project Team Member, Deliverable, Team Member, Physical Location, or Team Member Resource.

1 Level

  • Includes the Project, Project Team Member, and Deliverable records

  • Does not include Team Members, Physical Location, or Team Member Resources.

2 Level

  • Includes the Project, Project Team Member, Deliverable, Team Member, and Physical Location records. This level automatically includes parent records.

  • Does not include Team Member Resource.

3 Level

Includes the related records from all of the objects shown.

All Child Objects

Includes the related records from all of the objects shown.

Custom

Includes your custom selection of the related records to include. Use the above definitions to define your selection.


📝 Note

The selection of a child record always includes the parent records, as a child record cannot exist without the parent (i.e., orphan records).


Extract, Transform, and Load Process Overview

Data copies are created using an extract, transform, and load (ETL) procedure. The following sections explain each stage in the ETL process.

Extract

This stage extracts records from the source specified in the data template. When determining the fields to query, the application only considers fields, which exist on both the source and destination and are accessible by the user through field permissions.

Transform

The application considers the query result from the extraction stage and applies transform procedures in the following order:

  1. Data Translation

  2. Data Mask


📝 Note

If a data translation and data mask operation are set for the same object field, the data mask operation occurs on the translated value.


For more information, see Data Translations and Data Mask.

Load

This is the final stage, which copies the records to the destination org.

The application determines if the record(s) should be updated or created based on the external ID settings. For more information, see External ID.

If the records lock other records during a data copy, the application keeps track of the locked records and automatically performs sequencing for loading of the records. The application considers the following types of record locking:

Lock Type

Resolution

Master-Detail Relationships

The application tracks the locked master records and performs the insertion in sequence accordingly.

Lookup Relationships

The application tracks the locked lookup records and performs the insertion in sequence accordingly.

If the lookup field is set to Don't allow deletion of the lookup record that's part of a lookup relationship setting in Salesforce, the lookup records are locked.

Roll-up Summary Fields

The application tracks locked master records and performs the insertion in sequence accordingly.

Triggers

The application disables triggers by default during a data copy.

Workflow Rules

The application disables workflows by default during a data copy.

Group Membership Locks

The application does not consider group membership locks during a data copy.

For more information, see Group Membership Locks (https://developer.salesforce.com/blogs/engineering/2012/09/group-membership-operation-already-in-progress-managing-group-membership-locks-for-success.html).

For more information on record locking, see Salesforce Record Locking - https://developer.salesforce.com/blogs/engineering/2014/07/record-locking-cheat-sheet.html

Did this answer your question?