Skip to content

Latest commit

 

History

History
88 lines (54 loc) · 5.61 KB

ReadMe.md

File metadata and controls

88 lines (54 loc) · 5.61 KB

QuickCompare

Build Status CodeQL Quality Gate Status Reliability Rating Security Rating Vulnerabilities

A simple, fast, free SQL database schema comparison library/app written in C#

This package interrogates the schema of two Microsoft SQL Server databases and reports on the differences between them. There is a front-end for Windows users and a NuGet package for .NET developers and DevOps engineers.

It is free to use without any restrictions (and always will be) and everyone is encouraged to contribute improvements to the project and raise issues as appropriate. If you find this project useful, consider clicking the star to add to your favourites!

demo-screenshot

How it works

Using some SQL queries (mainly targeting the INFORMATION_SCHEMA views), the solution uses low-level asynchronous DataReader instances to populate models in the DatabaseSchema namespace.

Next the engine inspects models of both databases, building a set of Difference objects for each database element.

The Difference objects also act as a report generator, with overridden ToString() methods a generated report will list all database differences.

Input parameters are accepted via the IOptions implementation; QuickCompareOptions. This aids automation because it allows the application to be easily run by anything that can provide application settings (such as Azure Pipelines).

Purpose

Many paid solutions are very expensive and still return large numbers of false-positive results or even miss important differences that are not detected at all.

False-positive results from other solutions might also include differences in remarks/comments, line-breaks or whitespace - all of which can be time-consuming to check but can be ignored in QuickCompare. If these differences do not affect the schema or functionality of the database, then you should be able to choose to ignore them.

Finally, nobody seems to offer a simple database comparison solution that meets these needs for free - even less so if you want to use them programmatically with C#.

So here is a free alternative that will remain open-source and fully unit-tested for anyone to use.

It is lean enough to be used in CI/CD pipelines and as it targets information schema views, it does not negatively impact the performance of the databases under interrogation.

Please contribute to the source code if you have the time/knowledge to spare!

Example usage

The DifferenceBuilder class builds the report from the Differences collection as shown in this example.

var settings = new QuickCompareOptions
{
    ConnectionString1 = "Data Source=localhost\\SQLEXPRESS;Initial Catalog=Northwind1;Integrated Security=True",
    ConnectionString2 = "Data Source=localhost\\SQLEXPRESS;Initial Catalog=Northwind2;Integrated Security=True",
};

IOptions<QuickCompareOptions> options = Options.Create(settings);

var builder = new DifferenceBuilder(options);
await builder.BuildDifferencesAsync();
string outputText = builder.Differences.ToString();

The options are usually injected from the configuration, but are explicitly created in this example for clarity.

Status event handling

Inspecting two databases for differences is quick, but it is far from instantaneous. You can measure progress by handling status changes.

The DifferenceBuilder class raises an event when the status changes - subscribe to ComparisonStatusChanged to return an instance of StatusChangedEventArgs. This EventArgs instance has a property named StatusMessage which could be presented in a UI layer or used to measure timing of steps.

An example of consuming this event can be found in both WinQuickCompare and the sample console application.

Database SQL queries

The SQL queries are located in the folder DatabaseSchema/Queries. These have been written for backwards-compatibility with SQL Server 2000.

The queries do not require special permission for the master database and have minimal impact on database performance, even during busy periods.


Consider this a pre-release version until the first release appears on the GitHub project page!

To-Do:

  • Compare System-Versioned table properties
  • Compare Database properties (e.g. compatibility version)
  • Add "upload report" feature for DevOps (XML/JSON?)
  • Change Windows UI to display a tree view or similar(?)