Moving database from Azure SQL to localdb
I recently moved an Azure SQL database back to a local development database and ran into a few issues. I took these notes so that they might help the next person that hits the problem.
In my local SSMS, I use the Import/Export wizard with the datasource using SQL Server native client 11.0. This moves the tables and data. Any destination tables will not have IDENTITY as the source tables did.
Solution # 1
Move away from INT Identity to use GUIDS. This requires work in the database and client code but is the better choice if you need to move data out of the source datatabase then back into the source database.
Solution #2
More immediate fix to get past the block that your inserts don't autoincrement.
Steps:
The following steps are completed in SSMS in the destination (local) database and should have all the data but not the IDENTITY column.
- Rename the mytable to mytable2.
- Generate CREATE, INSERT, and SELECT scripts for the table.
- Modify the CREATE script to use the table name (change mytable2 to mytable) and change the PK row to include the identity requirement.
CREATE TABLE [dbo].[mytable]([Id] [int] IDENTITY (1,1) NOT NULL,[Text] [nvarchar](40) NULL,) ON [PRIMARY]GO
- Run the creation script.
- Create second script from the INSERT/SELECT scripts
SET IDENTITY_INSERT mytable ON
INSERT INTO [dbo].[mytable]
([Id]
,[Text])
SELECT [Id]
,[Text]
FROM [dbo].[mytable2]
SET IDENTITY_INSERT mytable OFF