Feb 24 2020 07:04 AM
Feb 24 2020 07:04 AM
I have implemented a basic C# application connected with On premises SQL Server, I am going to migrate the same database and the data to Azure cloud using Microsoft Migration Tool, After the migration without touching the coding part I am debugging the same application (Changed the connections string only).
On premises sql database connected with SQL Server,
In the database I am running this query through management studio and I am getting the following results,
Same query I am deploying through my developed C# application, I am testing the connection with sql authentication credentials
String source = @”Data Source =” + textBox1.Text; Initial Catalog = CheckPostingDb; User Id =” + textBox2.Text;; Password=” + textBox3.Text;
SqlConnection con = new SqlConnection(source);
Once it’s succeeded, I’m running the same query through sqlcommand function in C#, got the same results in the text box
String sqlSelectQuery = “SELECT COUNT(*) AS MREQUESTS FROM MREQUESTS WHERE REQSTATE=1”;
SqlCommand cmd = new SqlCommand(sqlSelectQuery, con);
textBox4.Text = Convert.ToString(dr[“MREQUESTS”])
Let’s migrate to Cloud
I have deployed a sample database in the Azure Cloud with SQL authentication,
It’s just a blank database and it doesn’t have any tables
Tried the same query here and returning with failed errors,
Start ab new project type as Migration
In this step I am specifying the source and target server details
In my scenario Source server is in localhost and target sql server is in Azure could
Source Server — localhost , Target Server — gohulan.database.windows.net
Select the Correct database from the source server to Migrate to cloud,
In the target server select the correct database from Azure cloud, in my Azure cloud I have only one database named CheckPostingDb
Once its’s connected I am going to select the objects or tables from the source database that I would like to migrate
In my testing environment I am selecting only one table, my table is MREQUESTS since I am targeting the results only from this table through my C# application.
Once the table is ticked, I have generated the SQL script
Once the script is generated, I am deploying the schema,
/******** DMA Schema Migration Deployment Script Script Date: 2/24/2020 12:50:55 PM ********/
/****** Object: Table [dbo].[MREQUESTS] Script Date: 2/24/2020 12:50:55 PM ******/
SET ANSI_NULLS ON
SET QUOTED_IDENTIFIER ON
IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N’[dbo].[MREQUESTS]’) AND type in (N’U’))
CREATE TABLE [dbo].[MREQUESTS](
[ID] [bigint] IDENTITY(1,1) NOT NULL,
[RID] [uniqueidentifier] NOT NULL,
[ReqTime] [datetime] NOT NULL,
[ReqState] [tinyint] NOT NULL,
[RecordType] [int] NOT NULL,
[Data1] [bigint] NULL,
[ServiceID] [int] NULL,
[FirstRequestTime] [datetime] NULL,
[OfflinePosting] [bit] NULL,
[ServiceHostInfo] [nvarchar](80) COLLATE SQL_Latin1_General_CP1_CI_AS NULL,
CONSTRAINT [PK_MREQUESTS] PRIMARY KEY CLUSTERED
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON)
IF NOT EXISTS (SELECT * FROM sys.indexes WHERE object_id = OBJECT_ID(N’[dbo].[MREQUESTS]’) AND name = N’AK_MREQUESTS_RID’)
CREATE UNIQUE NONCLUSTERED INDEX [AK_MREQUESTS_RID] ON [dbo].[MREQUESTS]
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON)
IF NOT EXISTS (SELECT * FROM sys.indexes WHERE object_id = OBJECT_ID(N’[dbo].[MREQUESTS]’) AND name = N’IX_MREQUESTS_2')
CREATE NONCLUSTERED INDEX [IX_MREQUESTS_2] ON [dbo].[MREQUESTS]
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON)
After I deployed the generated script in the previous step, it doesn’t give any errors or warnings.
Once the script is migrated, I can see my table was created in the Azure cloud. But my query was returning with 0 results, it means that MREQUESTS table has been deployed but not the data yet.
I am migrating the data as well in my next step
Once after I started the migration it will start the process to send the data to cloud, time depends on the data capacity and the network speed.
Since my table doesn’t have huge data it finished with in short time without any warning or errors.
Running the same query in the Query Editor in Azure to check my data, it’s succeeded and returned with same value as on-premise query returns earlier.
Returning to my C# application and no changes made in the application but changing the connection string by changing the server name and sql authentication credentials,
Debugging the application to confirm it’s functioning properly, tested my connection with correct sql credentials
Wow the results as expected, means Migration is succeeded.