Contact merge

Current version: 10.2
Note

From Sitecore version 10.1, the contact merge logic has changed. Profile scores merge from the source to target based on the latest SourceInteractionStartDateTime. See Contact behavior profile.

A contact merge is triggered when a returning anonymous contact that already exists in xConnect identifies as a known contact. The tracker is responsible for sending a request to xConnect for the two contacts to be merged. Merge logic is owned by xConnect. The following steps describe how a merge is triggered from the tracker:

  1. An anonymous contact visits a few pages of your website - at the end of their session, they are saved into xConnect as an anonymous contact.

  2. The anonymous contact visits your website again from the same device. The analytics cookie makes it possible to identify the contact as an existing contact. The anonymous contact is loaded from xConnect. Because the anonymous contact already exists in xConnect, the IsNew property on Sitecore.Analytics.Tracker.Current.Contact is set to false.

  3. During this second interaction, the anonymous contact identifies as a known contact:

    RequestResponse
     ServiceLocator.ServiceProvider.GetRequiredService<IContactIdentificationManager>()                .IdentifyAs(new KnownContactIdentifier("twitter", "myidentifier"));
    
  4. The mergeContacts pipeline (configured in \Website\App_Config\Sitecore\Marketing.Tracking\Sitecore.Analytics.Tracking.config) executes on the Content Delivery server. This pipeline belongs to the tracker and is responsible for two things:

    • Sending a merge operation to xConnect. A series of merge handlers are executed in xConnect which merges any anonymous contact data (such as facets) into the known contact.

    • Merging contact classification; this is the only data that the tracker is responsible for merging.

    Note

    If the contact does not exist in xConnect, step 1 is not executed and no merge is triggered in xConnect. However, step 2 is always executed.

  5. The merged contact is reloaded in session - this includes reloading all facets.

Note

Because xConnect owns the contact merge logic, it is unlikely that you will need to extend the mergeContacts pipeline. It is more likely that you will need to create merge handlers for custom facets.

Classification merge

The tracker is responsible for merging classification data. The MergeContactsClassification processor executes if:

  • The known contact (the target of the merge) has been classified as a robot (classification >= 900) OR

  • The anonymous contact (the source of the merge) has been classified as human (classification < 900)

The System.Classification and System.OverrideClassification properties with the greatest values are saved to the target contact.

Merging contacts in batch

We recommend that you run contact merges as a single operation in a batch, to avoid data corruption or unexpected behavior. It is possible to process a contact merge in batch with other operations, but you must ensure that the other operations do not retrieve or modify the contacts used in the merge operation.

Do you have some feedback for us?

If you have suggestions for improving this article,