Introduction to Dynamics 365 CE Data Migration using ADF
Dynamics 365 CE Data Migration using ADF can be necessary for various reasons, such as archiving historical data, integrating with other systems, or performing data analysis in a different environment. However, extracting and transforming data from Dynamics 365 CE Service can be challenging due to its complex data model and security considerations.
Azure Data Factory (ADF) offers a robust solution with its Metadata-Driven Pipeline feature. This approach of Dynamics 365 CE Data Migration using ADF enables you to define your data extraction process using metadata, including source entities, data fields, and transformations.
By leveraging this Dynamics 365 CE Data Migration using ADF approach, you can:
- Streamline data extraction: Automate the process of identifying and retrieving data from Dynamics 365 CE.
- Improve data quality: Ensure data consistency and accuracy during the extraction process.
- Enhance security: Implement robust security measures to protect sensitive data during migration.
- Increase efficiency: Accelerate the data extraction process and reduce manual effort.
In this blog, we will attempt to move Case records from Dataverse to Azure Storage Account Container as a JSON blob file.
Steps for Dynamics 365 CE Data Migration using ADF
Step 1:
Visit your Azure Resource group and create a Data Factory resource. Once deployed, launch the studio.
data:image/s3,"s3://crabby-images/89229/8922989f80101a96a926a7c4600d2c885aa06429" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 1 Azure Resource Group"
data:image/s3,"s3://crabby-images/e2cb8/e2cb87425eee582cda67738babf9a0b2e0c4fa37" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 2 Create Data Factory Resource"
Step 2:
In the ADF studio, create Linked Services for your Microsoft Dynamics 365 CRM or Dataverse D365 CE environment and the target Azure Storage Account Blob container.
Dataverse Linked Service:
data:image/s3,"s3://crabby-images/76a5b/76a5beb104120f336a8563333bf523cf0dbd0ded" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 3 Dataverse Linked Service"
It is highly recommended to choose the Service Principal as the Authentication Type. Once you have entered the values for Application ID and the Secret key, test the connection.
data:image/s3,"s3://crabby-images/2191e/2191e73409fbf8af3000e8b975ce37b80dd37ea9" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 4 Service Principal as Authentication Type"
Azure Storage Account Linked Service:
data:image/s3,"s3://crabby-images/6d1aa/6d1aa1575d8cd31944c897e1f8ff4201b964d9a4" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 5 Azure Storage Account New Linked Service"
data:image/s3,"s3://crabby-images/7ac05/7ac051f9dbc4aed5416de687ec20421f86b0ef5f" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 6 Azure Storage Account Linked Service"
Step 3:
Once both the Linked Services are created, navigate back to your ADF studio, click on the Ingest option and choose metadata-driven Copy Task. From there, we will set up the Control Table.
data:image/s3,"s3://crabby-images/768e1/768e107429d1cd8c4a778dfc29351d2658926bee" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 7 Ingest Option"
data:image/s3,"s3://crabby-images/8fd77/8fd77c481f35394701c989140c6fc819bbb6ae07" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 8 Metadata-driven Copy Task"
Step 4:
Have an SQL Server and DB as prerequisite. Now, select Type as Azure SQL Database, choose your Azure Subscription, Sever Name, Database Name & Authentication Type = System Assigned Managed Identity.
data:image/s3,"s3://crabby-images/5ce96/5ce961117b31256fff025e56aeee0229509ebdaa" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 9 SQL Server and DB as Prerequisite"
Step 5:
Here comes the most important bit. We need to configure the system assigned managed identity by running a T-SQL script in SSMS (SQL Sever Management Service) tool. The script would create the Managed Identity as a user and elevate the privileges to DB owner.
data:image/s3,"s3://crabby-images/e556e/e556ee0d288750a06e154ac0f6b544f07e43b2f4" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 10 Running T-SQL Script in SSMS"
CREATE USER <Managed Identity> FROM EXTERNAL PROVIDER; ALTER ROLE db_owner ADD MEMBER [Managed Identity] |
Step 6:
Test connection to the Linked Service.
data:image/s3,"s3://crabby-images/fcc99/fcc992e115cf2bd1ba612ec4390631a7868396ce" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 11 Test Connection to Linked Service"
Step 7:
Next, specify your data source as your Dataverse Linked Service.
data:image/s3,"s3://crabby-images/55472/5547261aa9ad368156731b0c3b47cdc5692902ea" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 12 Specify Data Source"
Step 8:
We select the first table for which we wish to fetch the data from. In our instance, we are selecting the Case (Incident) table.
data:image/s3,"s3://crabby-images/6aba4/6aba497ffe6b52d84c7ec00d5c46bae86f84efd3" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 13 Select Case (Incident) Table"
data:image/s3,"s3://crabby-images/be10d/be10d352d0326e400e2ae709154f47325abb80af" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 14 Choose Loading Behavior"
Step 9:
On the next step, select the Azure Blob Linked Service as Destination Data Store, specifying the target file path and name.
data:image/s3,"s3://crabby-images/8efa5/8efa5cd1fe63c25407278569197551f84f30edbf" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 15 Destination Data Store"
Step 10:
Then, we select File format as JSON, and its pattern as “Array of objects”.
data:image/s3,"s3://crabby-images/ed55e/ed55e9978185cd78e9a96c4cf9204c5a1619d75f" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 16 File Format Settings"
Step 11:
On the next step, we ensure that the system has auto-mapped the fields correctly.
data:image/s3,"s3://crabby-images/22c91/22c918c0d4ad8ddda818d69d77139a4b62c50ab5" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 17 Schema Mapping"
Step 12:
We give a custom name to the our ADF Copy Task.
data:image/s3,"s3://crabby-images/0b37c/0b37c5ea9a34fbcc3939fc98b5122ff302891163" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 18 Custom Name to ADF Copy Task"
Step 13:
Finally, we check the summary of this entire configuration before we click Finish.
data:image/s3,"s3://crabby-images/27a1d/27a1d595851456284319aa4f87496716decbb203" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 19 Check the Summary"
Step 14:
On the completion of deployment, we will get an SQL script generated. We execute it in the SSMS tool as a new query.
data:image/s3,"s3://crabby-images/7feb1/7feb1427a073367fb85a3ace67873a3fa49b06ed" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 20 Deployment Complete"
data:image/s3,"s3://crabby-images/015a3/015a32e92ccc683a50d97d69dd2fa6e926950651" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 21 SQL Script Generated"
Step 15:
After the successful execution of the script, we finish setting up the entire configuration on the Azure portal. We would see that under our pipeline, 3 tasks components are created which will drive our Integration – Top Level (Control Table), Middle Level & Bottom Level.
data:image/s3,"s3://crabby-images/4ef0e/4ef0ec8a2f37bd1a9e68c7a563240a5bd7e0351d" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 22 Setting up Configuration on Azure Portal"
Unit Testing
- We execute the Pipeline by clicking the Debug button and very for the execution of the 3 tasks.
data:image/s3,"s3://crabby-images/f7d37/f7d379d892b551f5c64a6626498b9a7e81faa7b6" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 23 image 28"
- We confirm that Incident JSON blob is created as expected.
data:image/s3,"s3://crabby-images/cc784/cc78412b88deca3d9b52e904d6f823944ea15f81" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 24 image 29"
- Resultant JSON array is as follows:
data:image/s3,"s3://crabby-images/fa0b4/fa0b430890351c4b9be59cc80d8b0a7463c46af1" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 25 image 30"
- We also add the “Subject” table to the list of tables as follows.
data:image/s3,"s3://crabby-images/24843/24843c4158d15a11a693a08dff430ba8b9f88796" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 26 image 31"
data:image/s3,"s3://crabby-images/69250/6925016e207505ddb0b07a489f87df17952744ba" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 27 image 32"
- We again get an updated T-SQL script that we will execute again in SSMS tool.
data:image/s3,"s3://crabby-images/82516/825166defcec2d6a8a04b44a9f763a82bc547d25" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 28 image 33"
data:image/s3,"s3://crabby-images/86f96/86f9639b0400bfcc8139ae0dc604e52cb3534c8b" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 29 image 34"
- Now our Control Table has 2 rows, 1 for Case and another row for Subject.
data:image/s3,"s3://crabby-images/80c73/80c733e4b05276ca61914f8243efba7827185898" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 30 image 35"
- Finally, when we execute our pipeline again, we confirm that JSON blobs are created for both now – Case and Subject tables.
data:image/s3,"s3://crabby-images/bc61e/bc61e9da3d2ad79dffb59ecc914f1ace31e1395e" alt="How to Migrate Data from Dynamics 365 CE to Azure Using ADF 31 image 36"
Conclusion – Dynamics 365 CE Data Migration using ADF
Hence, we learnt in this blog how we can implement Dynamics 365 CE Data Migration using ADF metadata-driven pipelines. The Dynamics 365 CRM consulting team appreciated how easy it is to configure for multiple Dataverse tables.