Worked example - synchronizing data in two databases
Published 23 January 2013
This worked example demonstrates a basic comparison and synchronization of two SQL Server databases.
In the example, the Magic Widget Company has a SQL Server database running on a live web server. This database contains a number of tables, views, stored procedures, and other database objects. The Magic Widget Company's development team has been working on an upgrade to their website. As part of this upgrade, they have made a number of changes to the database, which need to be transferred to the production database.
You can follow the example on your own system. You will need access to a SQL Server to do this.
This example has three steps:
- Set up the comparison
Create the example databases, and specify the data sources, tables, and views you want to compare. - Select data to synchronize
Review the results and select the rows you want to synchronize. - Synchronize the databases
Create and run a synchronization script.
The worked example uses the following sample databases:
- WidgetDev is the development database
- WidgetLive is the production database
Set up the comparison
In this example, there are three steps to setting up the comparison:
- Create and specify data sources
- Select tables and views
- Set object mappings
It is not always necessary to set object mappings. However, in this example there are some schema differences between the source and target.
For more information, see Mapping objects
Create and specify data sources
- To create the databases, paste the SQL creation script into your SQL editor, then run it.
The databases are created and populated with data. - Start SQL Data Compare if it is not already running.
The Project Configuration dialog box is displayed showing your most recent project:
You can edit the current project, or create a new project.
If you want to create a new project, click Cancel to close the dialog box, and on the toolbar click (New Project).
If you have any existing projects, and the Projects dialog box is displayed instead, click New Project. - In the shaded upper pane, ensure the Source and Target are set to Database.
In this example, we will compare databases. You can also compare backups and scripts folders. - For each data source, in the Server box, type or select the name of the server on which you set up the databases.
- For the source, in the Database box, type or select WidgetDev.
For the target, type or select WidgetLive.
If the databases are not displayed in the Database lists, right-click in each Database box and click Refresh, or scroll to the top of the list and click Refresh.
Select tables and views
- To specify the tables and views you want to include, click the Tables & Views tab:
The Tables & Views tab enables you to specify:- the tables and views you want to compare
- which specific columns you want to compare
- the comparison key SQL Data Compare uses to match rows in the two databases
By default, SQL Data Compare does not compare views. To include views, on the Options tab, select the check box for Include views:
The Options tab allows you to modify the behavior of SQL Data Compare during comparison and synchronization.- Click the Tables & Views tab again.
The WidgetPriceList view is now included in the comparison.
Set object mappings
- To include the remaining columns, click the Object Mapping tab:
The Object Mapping tab displays a list of table and view mappings.
Mappings define which tables and views can be compared. For example, the table WidgetDescriptions in WidgetDev is mapped to WidgetDescriptions in WidgetLive. However, it can be mapped to any table with a sufficiently similar structure.
You can use the object mappings to compare tables with different or similar names.
The table WidgetPrices shows a Partial mapping, as not all of its columns could be automatically mapped. - To view and edit the column mappings, click Partial for the WidgetPrices table:
A dialog box is displayed for you to edit the column mappings: - In the lower pane of the dialog box, click DateValidFrom and then ValidFrom, and then click Map to map the columns.The columns move to the upper pane of the dialog box.
- Map the DateValidTo and ValidTo columns in the same way, and click Close.The status for the WidgetPrices table changes to Mapped.
- Click Compare Now.
SQL Data Compare displays a message dialog box that shows the progress of the comparison. If you select the Close dialog box on completion check box, SQL Data Compare closes this message dialog box automatically the next time that you run a comparison on a project. For this example, leave the setting as it is, and click OK to close the message box.
Select data to synchronize
The comparison results are displayed in the main window.
In this example, the comparison results are grouped by:
tables or views with differences in their rows
tables or views with identical rows only
To display the comparison results in a single list, in the Group by box, select No groups.
To display the comparison results in groups, select Type of difference.
To view the comparison results for each object group, click or click the grouping bar:
The upper (Results) pane also shows how many rows of each type exist for each table or view. For example, the table WidgetPrices contains:
- three rows that exist in WidgetDev but not in WidgetLive
- one row that exists in both databases but has different values
- no rows that exist in WidgetLive but not in WidgetDev.
The Identical column shows that there are two rows that are identical.
Finding objects
To locate objects, type the search text in the Find box. To select a recent search, click the Find arrow button
As you type, objects are grouped in the upper pane by whether they match or do not match what you type:
SQL Data Compare searches object names and owners (schemas).
Note that the search is not case-sensitive.
To clear the Find box click the button.
Viewing row differences
To view detailed information about the data in a table or view, click on it in the upper pane. The lower (Row Differences) pane is displayed.
Click the table WidgetDescriptions to see the row differences:
In this example WidgetID is the comparison key , used by SQL Data Compare to match rows in the two databases.
For the row where WidgetId is 2, the values for Short Description and Description are the same in both databases, so the data is displayed in gray text.
The Picture values are different so they are displayed with the darker shaded background.
To view a specific value in a row double-click it, or right-click and select Show Viewer. Binary Data values are displayed as links. Click the Binary Data link for the row where WidgetId is 2.
For tables or views that contain a large number of columns, you may find it useful to display the column values vertically so that you can see records more easily. To do this, click Show, then Pivot View
To display the column values horizontally again, click Show, then Pivot View
You can move through each difference in turn using the and buttons. To move through the differences for the current column, click or
Selecting rows to synchronize
Use the check boxes in each pane to select data for synchronization. You can select individual tables or views to synchronize, and for each table or view you can select the rows that you want to synchronize. By default, all rows that differ are selected when you run a comparison.
For this example, select all the tables and their rows. Ensure that the check boxes are cleared for the WidgetPriceList view. You do this by clearing the Different check box for WidgetPriceList:
The number of rows selected for synchronization is shown in the Direction Bar.
To synchronize, click Synchronization wizard.
Synchronize the databases
On the first page of the Synchronization wizard you can choose to create and save a synchronization script, or perform the synchronization using SQL Data Compare.
Choose synchronization method
In this example, we will synchronize using SQL Data Compare.
- Make sure Synchronize using SQL Data Compare is selected.
- Clear the Back up target before synchronization check box if it is selected.
In this example, we will not back up before synchronization.
For more information, see Backing up before synchronization - To generate the synchronization script, click Next
The Review page is displayed.
Review the synchronization script
There are three tabs on the Review page:
- Synchronization script shows the script to synchronize the data sources.
You can search the script, save it, or copy it to the clipboard. - Summary shows a synopsis of the actions in the synchronization script.
You can view the summary grouped by the objects affected, by the type of modification, or by the order in which the script modifies the target. - Warnings shows a list of any warnings about unexpected behavior that may occur when you synchronize the databases.
For more information, see Warnings.
Perform the synchronization
When you have reviewed the script, synchronize the databases:
- Click Synchronize Now to perform the synchronization.
- A confirmation dialog box is displayed. Click Synchronize Now to continue.
- SQL Data Compare displays a message dialog box that shows the progress of the synchronization.
When the synchronization is complete, click OK to close the message box.
SQL Data Compare then re-compares the databases. The results are shown in the main window. In this example, all tables and their rows are shown to be identical, confirming that the synchronization has been a success.
Note that the WidgetPriceList views are also now identical, because the tables that they reference have been synchronized: