Dual-write has been around for almost two years now. It’s one of the ways of integrating Dynamics 365 Finance and Operations and Dataverse along with Virtual Entities.
The standard solution comes with many out-of-the-box entities available to synchronize. This has been one of the great improvements since Dual-write was made available in preview, when Juanan and I demoed it in the 2019 Dynamics Saturday in Madrid.

But what if we need to develop a new custom Data Entity in MSDyn365FO and use it in Dual-write? It’s easy but there’s some things we need to remember when doing it.
Dual-write
Dual-write is a bidirectional integration that will synchronously write in Dataverse when data is created, updated or deleted in MSDyn365FO in near-real-time. On the Finance and Operations side it uses data entities to export data to Dataverse.
Right now there’s a set of several OOB entities that come ready to be synchronized, and thanks to Initial Sync we can populate data in Dataverse choosing FnO as the source when starting the sync, or also choose Dataverse as the source.
If you want to learn more about Dual-write you can:
- Read the docs which have plenty of information. Read the docs. Always.
- Guidance for Dual-Write setup
- System requirements and prerequisites
- Watch some of Faisal Fareed‘s sessions about Dual-write: DynamicsCon 2020: The Power of Dual-write or Scottish Summit 2021: D365 FO integration with Dataverse – Dual write, Virtual Entities, OR Data Integrator. He’s got some more which you can find on Youtube.
Create the Data-entity
In Visual Studio we need to create the entity from our table. I’ve created a new table called AASBookTable with just four fields: BookId, Author, Name and ISBN. Its primary key is the BookId field which is also its alternate key and will be used as natural key in the entity.
Next, we create the data entity and make sure we’re marking the “Enable data management capabilities” checkbox:

If the entity doesn’t have data management enabled it won’t be displayed in the list in the Dual-write tables setup.
Create a table in Dataverse
Now we need to create a table in our Dataverse environment. This table must have at least some of the fields we want to synchronize to Dataverse AND a company field. The company concept doesn’t exist in Dataverse/CRM but thanks to the OOB mappings and Initial Sync we can solve this with just a few clicks and will have a company table in Dataverse with all our FnO legal entities.

Following my example I’ve created a table with the same four fields and a company field with the data type Lookup and its related table Company, where the FnO legal entities are synchronized.
As I said, if we don’t create this field we won-t be able to setup Dual-write for this table.
Create table map
Our table and data entity are ready, and now we need to create a mapping between them in the Dual-write workspace in FnO. Click the “Add table map” button:

A new dialog will open and we need to select the FnO entity and the Dataverse table:

Select the entity and table we’ve created and click save. Then we can define the field mapping:

Because I’ve created both it’s clear what to map. And after doing this we can click save and it’s done, right? No! WRONG! If we do just this we’ll get an error, this error:
Project validation failed. SourceEntitySchema: Books has a primaryCompanyField set to DataAreaId and DestinationEntitySchema: cr008_bookses doesn’t have primary company field set. Dual-write only supports mapping between cross-company entities or company-specific entities from both sides..keys are missing for either AX or CRM.keys are missing for either CRM or AX
Or we can also get an error regarding a missing integration key for the company field. In the end both are caused because we’ve missed defining the integration key for this new Dataverse table:
Integration key
Go back to the main Dual-write form and click on the “Integration key” button:

The integration key will be the same as the FnO data entity key, plus the company if your data entity has a company context. Remember that when we create indexes in FnO the DataAreaId field isn’t included in the field, but it is in the SQL Server index along the partition field.
The integration key for our custom Dual-write mapping will look like this:

Remember we’ve added the company field to our Dataverse table? You can see in the image above that the field includes the relation to the Company table in Dataverse. We won’t be able to save the field mapping if we create the key using our Dataverse table’s company field instead of its Company table relation, like this:

See the difference? In the first image the field reads c008_company.cdm_companycode while in the second one it’s c008_company. If we set the integration key using the field in our table instead of the related table and save the fields’ mapping we’ll get an error saying the company is missing in the key because it’s expecting the relation!
Action!
The table and field mappings are ready, just click run and go create a new book in the FnO form:

Then we go to our Dataverse table and check its data…

It’s there! And of course it’s working in both directions. If I create a record in Dataverse it’ll be created in FnO too. I’ll use the Excel add-in to add a new book:

And after refreshing the form in FnO we can see it there too:

This is a really simple example of how we can create a custom table, use it in a data entity and then use this entity in our dual-write setup. It’s something that can be easily done but we need to remember the “company thing”, otherwise this will never work!
Dual-write is even easier to configure nowadays thanks to LCS allowing us to create and link a new Dataverse environment when we deploy a new Finance and Operations environment.
 
				
		 
			 
			 
			 
			 
			 
			
6 Comments
Thank you. Very well explained. I followed your tutorial and mKe the custom entity every operation work prefectly (create and update) but delete is not working. When I delete the line from F&O it could not delete from data verse.
Are you getting any errors?
Hi, This is a great post with detailed steps on how to do dual write integration with custom entities in CE. I have a question related to the custom entities integration. How can we sync records through dual write if two tables in CE have N:N relationships and I want to show the same on F&O?
You need to create a key that allows data to be updated on F&O entities. F&O entities need a natural key (human-readable) that allow a single record to be identified, if you can do that then it will work, though it’ll be harder, or even impossible, with N:N relationships…
Hi sir i am facing this error
Project validation failed. [DIPV1034] Key field cr3fd_company.cdm_companycode in rodic_riskanalysises of CRM must be mapped to a key field in PRO_RiskLog of AX.
Hi Dipesh, you need to configure the integration key for that entity on the main Dual Write form.