top of page
OmniStudioFactBg.png
Writer's pictureGayathiri Mohan

Use of LISTMERGE and LISTMERGEPRIMARY functions in DataRaptor Formulas

In this article, let us see how to use the functions ‘LISTMERGE’ and ‘LISTMERGEPRIMARY’ in the DataRaptor formulas.


LISTMERGE function:

This function is used to merge any number of lists by combining their entries when the values of the specified keys match. 

To achieve this purpose, 

  • the keys used as a matching criteria should be specified as a comma-separated list of quoted key names and

  • the lists to be merged should be specified with the LIST function, separated by a comma.

If the lists contain ‘identically named nodes’ that contain different values, subsequent values overwrite earlier values in the result list. 

The final output contains all the keys from all the lists.


Example 1: Single matching key (‘Id’)

This example uses the LISTMERGE function with a single key.


Input:

{
  "CurrentAccounts": [
    {
      "Name": "Existing Account A",
      "Id": "0015i00000ecMumAAE",
      "BillingCity": "New York",
      "BillingCountry": "US"
    },
    {
      "Name": "Existing Account B",
      "Id": "0015i00000ecMumAAJ",
      "BillingCity": "Delhi",
      "Employees": 789
    }
  ],
  "ProspectiveAccounts": [
    {
      "Name": "New Account A",
      "Id": "0015i00000ecMumAAE",
      "BillingCity": "Paris",
      "Employees": 980
    },
    {
      "Name": "New Account B",
      "Id": "0015i00000ecMumAAJ",
      "BillingCity": "Chennai",
      "BillingCountry": "India"
    },
    {
      "Name": "New Account C",
      "Id": "0015i00000ecMumAAO",
      "BillingCity": "Bangalore"
    }
  ]
}

Formula:

LISTMERGE("Id", LIST(CurrentAccounts), LIST(ProspectiveAccounts))


Here, “Id” is the key based on which the lists ‘CurrentAccounts’ and ‘ProspectiveAccounts’ will be merged.


Formula Result Path:  FinalAccountsFromListMerge


Output:


If we observe the output, since we have used ‘Id’ as the matching criteria key,

  • The accounts with the same ‘Id’ (0015i00000ecMumAAE, 0015i00000ecMumAAJ) in both the arrays ‘CurrentAccounts’ and ‘ProspectiveAccounts’ are merged into a single entry in the final output array.

  • The nodes ‘Name’ and ‘BillingCity’ are present in both arrays (identically-named nodes), so in this case, the LISTMERGE function picks the node value from the last array, which is ‘ProspectiveAccounts’ in our example. So in the final output, we get the values as shown below,

Id

Name

BillingCity

0015i00000ecMumAAE

New Account A

Paris

0015i00000ecMumAAJ

New Account B

Chennai

  • For the remaining (non-matching) nodes, ‘BillingCountry’ and ‘Employees’, the values are picked up from the respective array elements. Hence, we get the output nodes corresponding to the Ids, as shown below.

Id

Employees

BillingCountry

0015i00000ecMumAAE

980

US

0015i00000ecMumAAJ

789

India

  • Finally, there is an extra element in the array ‘ProspectiveAccounts’ with the ‘Id’ : ‘0015i00000ecMumAAO’ and all the node values for this element are completely picked from the same array since there is no such element with the same ‘Id’ value in the first array ‘CurrentAccounts’.


Example 2: Multiple matching keys (‘Id’ and ‘Name’)

This example uses the LISTMERGE function with two keys.


Input:

{
  "CurrentAccounts": [
    {
      "Name": "Account A",
      "Id": "0015i00000ecMumAAE",
      "BillingCity": "New York",
      "BillingCountry": "US"
    },
    {
      "Name": "Existing Account B",
      "Id": "0015i00000ecMumAAJ",
      "BillingCity": "Delhi",
      "Employees": 789
    }
  ],
  "ProspectiveAccounts": [
    {
      "Name": "Account A",
      "Id": "0015i00000ecMumAAE",
      "BillingCity": "Paris",
      "Employees": 980
    },
    {
      "Name": "New Account B",
      "Id": "0015i00000ecMumAAJ",
      "BillingCity": "Chennai",
      "BillingCountry": "India"
    },
    {
      "Name": "New Account C",
      "Id": "0015i00000ecMumAAO",
      "BillingCity": "Bangalore"
    }
  ]
}

Formula:

LISTMERGE("Id,Name", LIST(CurrentAccounts), LIST(ProspectiveAccounts))


Here, “Id,Name” are the two keys based on which the lists ‘CurrentAccounts’ and ‘ProspectiveAccounts’ will be merged.


Formula Result Path:  FinalAccountsFromListMerge


Output:

Now, since we have used two matching keys: ‘Id’ and ‘Name’, the accounts in which both the nodes (‘Id’ and ‘Name’) match are merged into a single element. 

"Id": "0015i00000ecMumAAE",

"Name": "Account A"

The above values match for the elements in both arrays, so a single entry is created for ‘Account A’.


And the other elements that do not find a match are just picked up as a whole, and the final output array is created. 

So we get the below elements in the final array, 

* ‘Existing Account B’ from the ‘CurrentAccounts’ array.

* ‘New Account B’ and ‘New Account C’ from the ‘ProspectiveAccounts’ array.


NOTE: If you have a requirement to just combine two array elements without any matching key, you can use the LIST function instead. 


LISTMERGEPRIMARY function:

This function behaves similar to the LISTMERGE function, except that the output list contains only the keys from the first list.


Example 1: Single matching key (‘Id’)

This example uses the LISTMERGEPRIMARY function with a single key.


Input:

{
  "CurrentAccounts": [
    {
      "Name": "Existing Account A",
      "Id": "0015i00000ecMumAAE",
      "BillingCity": "New York",
      "BillingCountry": "US"
    },
    {
      "Name": "Existing Account B",
      "Id": "0015i00000ecMumAAJ",
      "BillingCity": "Delhi",
      "Employees": 789
    }
  ],
  "ProspectiveAccounts": [
    {
      "Name": "New Account A",
      "Id": "0015i00000ecMumAAE",
      "BillingCity": "Paris",
      "Employees": 980
    },
    {
      "Name": "New Account B",
      "Id": "0015i00000ecMumAAJ",
      "BillingCity": "Chennai",
      "BillingCountry": "India"
    },
    {
      "Name": "New Account C",
      "Id": "0015i00000ecMumAAO",
      "BillingCity": "Bangalore"
    }
  ]
}

Formula:

LISTMERGEPRIMARY("Id", LIST(CurrentAccounts), LIST(ProspectiveAccounts))


Here, “Id” is the key based on which the lists ‘CurrentAccounts’ and ‘ProspectiveAccounts’ will be merged.


Formula Result Path:  FinalAccountsFromListMergePrimary


Output:


If we observe the output, since we have used ‘Id’ as the matching criteria key, 

  • The accounts with the same ‘Id’ (0015i00000ecMumAAE, 0015i00000ecMumAAJ) in both the arrays ‘CurrentAccounts’ and ‘ProspectiveAccounts’ are merged into a single entry in the final output array.

  • The nodes ‘Name’ and ‘BillingCity’ are present in both arrays (identically-named nodes), so in this case, the LISTMERGEPRIMARY function picks the node value from the last array, which is ‘ProspectiveAccounts’ in our example. So in the final output, we get the values as shown below,

Id

Name

BillingCity

0015i00000ecMumAAE

New Account A

Paris

0015i00000ecMumAAJ

New Account B

Chennai

  • For the remaining (non-matching) nodes, ‘BillingCountry’ and ‘Employees’, the values are picked up from the respective array elements. Hence, we get the output nodes corresponding to the Ids, as shown below.

Id

Employees

BillingCountry

0015i00000ecMumAAE

980

US

0015i00000ecMumAAJ

789

India

NOTE:

The remaining elements in the last array that do not find a corresponding match in the first array are ignored altogether. This is the only difference between the LISTMERGE and LISTMERGEPRIMARY functions.

So in our example, the element with “Name: New Account C in the ‘ProspectiveAccounts’ array is ignored.


Example 2: Multiple matching keys (‘Id’ and ‘Name’)

This example uses the LISTMERGEPRIMARY function with two keys.


Input:

{
  "CurrentAccounts": [
    {
      "Name": "Account A",
      "Id": "0015i00000ecMumAAE",
      "BillingCity": "New York",
      "BillingCountry": "US"
    },
    {
      "Name": "Existing Account B",
      "Id": "0015i00000ecMumAAJ",
      "BillingCity": "Delhi",
      "Employees": 789
    }
  ],
  "ProspectiveAccounts": [
    {
      "Name": "Account A",
      "Id": "0015i00000ecMumAAE",
      "BillingCity": "Paris",
      "Employees": 980
    },
    {
      "Name": "New Account B",
      "Id": "0015i00000ecMumAAJ",
      "BillingCity": "Chennai",
      "BillingCountry": "India"
    },
    {
      "Name": "New Account C",
      "Id": "0015i00000ecMumAAO",
      "BillingCity": "Bangalore"
    }
  ]
}

Formula:

LISTMERGEPRIMARY("Id,Name", LIST(CurrentAccounts), LIST(ProspectiveAccounts))


Here, “Id,Name” are the two keys based on which the lists ‘CurrentAccounts’ and ‘ProspectiveAccounts’ will be merged.


Formula Result Path:  FinalAccountsFromListMergePrimary


Output:

Now, since we have used two matching keys: ‘Id’ and ‘Name’, the accounts in which both the nodes (‘Id’ and ‘Name’) match are merged into a single element. 

"Id": "0015i00000ecMumAAE",

"Name": "Account A"

The above values match for the elements in both arrays, so a single entry is created for ‘Account A’.


And for the other elements in the first (primary) array that do not find a match, they are just picked up as a whole, and the final output array is created.

"Id": "0015i00000ecMumAAJ",

"Name": "Existing Account B"

In our example, the second element with the above values from the ‘CurrentAccounts’ array is just picked up as a whole and added to the final output array.

The remaining elements in the second array, ‘ProspectiveAccounts’ are ignored altogether.


Please read this blog for the usage of other LIST functions listed below: 

  • MAX

  • MIN

  • SUM

  • AVG

  • LISTSIZE

  • ISBLANK

  • ISNOTBLANK

  • LIST

  • SORTBY

  • FILTER


References:





751 views0 comments

Recent Posts

See All

List Functions in DataRaptor Formulas

In this article, let us see how to use functions that operate over lists in DataRaptor Formulas. We will see examples of the below ‘List’...

OmniStudioFactFooterBg.png
logo.png

OmniStudiofacts helps us to build a Vlocity/OmniStudio Tech Community which focuses on sharing technical skills and experience across the globe.

© 2023 by OmniStudioFacts.

bottom of page