I created a pipeline and two linked services to move data from an on-prem instance of SQL Server to an Azure Sql instance. The issue I\'m running into is that we have a table \
Azure Data Factory does not natively support switching the identity property of tables on or off, but two workarounds spring to mind.
https://github.com/Microsoft/azure-docs/blob/master/includes/data-factory-sql-invoke-stored-procedure.md
I have not been able to test these but believe they would work. Let me know if you have any issues.
I accepted wBob's answer but wanted to put a little more detail into what I did.
I had probably 100 tables to move over with all sorts of dependencies and identities. So here are the steps I carried out to get the data into azure:
Create a pipeline to move over all tables with no identity and no dependencies, found by querying sys.tables:
select *
from sys.tables t
where not exists (
select *
from sys.columns c
where c.object_id = t.object_id
and is_identity = 1
)
and bumped the results here up against the results of sp_msdependencies
where the oType = 8. I then took all of the tables in this result set where oSequence = 1 (no dependencies) and put those tables in the pipeline and ran it.
I created a Staging schema and re-created all of the tables with an identity column (found by removing the 'not' in the query in (1.), and there were over 60 of them) and removed the identity specification when creating them.
I then created another data factory pipeline to move the data into these Staging tables.
Ran a bunch of 'insert into...' statements to move the data from the staging tables into their identity-laden counterparts, setting identity_insert on and off each time. NOTE: Here, I also had to be mindful of the sp_msdependencies result so as not to get foreign errors
Created a data factory pipeline to move the remaining tables over.
Whew...