Diffinity 1.0.17

dotnet add package Diffinity --version 1.0.17
                    
NuGet\Install-Package Diffinity -Version 1.0.17
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Diffinity" Version="1.0.17" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Diffinity" Version="1.0.17" />
                    
Directory.Packages.props
<PackageReference Include="Diffinity" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Diffinity --version 1.0.17
                    
#r "nuget: Diffinity, 1.0.17"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Diffinity@1.0.17
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Diffinity&version=1.0.17
                    
Install as a Cake Addin
#tool nuget:?package=Diffinity&version=1.0.17
                    
Install as a Cake Tool

Diffinity

NuGet

Diffinity is a C# library and NuGet package for comparing database objects—such as stored procedures, views, and tables, between two SQL Server databases. It identifies differences and optionally applies changes to synchronize the objects. The library also supports generating detailed HTML reports summarizing the comparison, including links to view the source and destination definitions.

Diffinity can be used as a standalone library in your own applications or through the included console driver (Driver) for out-of-the-box functionality.

Features

  • Compares stored procedures, views and tables between two SQL Server databases.
  • Uses a hash-based comparison to detect changes efficiently.
  • Generates an HTML summary report of the differences.
  • Provides Side-by-side visual diffs of source and destination objects.
  • Optionally applies changes to the destination database to match the source.
  • Filters the report to show all objects or only those with differences.
  • Logs execution details to both the console and a log file.
  • Supports a .diffignore file to exclude specific procedures, views, or tables from comparison.

Getting Started

Option 1: Use the NuGet Package

Install the Diffinity library into your own project:

dotnet add package Diffinity

Option 2: Use the Console App (Driver)

To use the included console driver (Driver), clone the repository and follow instructions in the GitHub README:

📎 GitHub Repository

Example Usage

using Diffinity;
using System.Diagnostics;

internal class Program
{
    static void Main(string[] args)
    {
        var MyDbV1 = new DbServer("My Db V1", Environment.GetEnvironmentVariable("db_v1_cs"));
        var MyDbV2 = new DbServer("My Db V2", Environment.GetEnvironmentVariable("db_v2_cs"));
        string IndexPage = DbComparer.Compare(MyDbV1, MyDbV2);
        Process.Start(new ProcessStartInfo { FileName = IndexPage, UseShellExecute = true });
    }
}

Detailed Example Usage

using Diffinity;
using System.Diagnostics;

internal class Program
{
    static void Main(string[] args)
    {
        var MyDbV1 = new DbServer("My Db V1", Environment.GetEnvironmentVariable("db_v1_cs"));
        var MyDbV2 = new DbServer("My Db V2", Environment.GetEnvironmentVariable("db_v2_cs"));

        // You can optionally pass any of the following parameters:
        // logger: your custom ILogger instance
        // outputFolder: path to save the results (string)
        // makeChange: whether to apply changes (ComparerAction.ApplyChanges,ComparerAction.DoNotApplyChanges)
        // filter: filter rules (DbObjectFilter.ShowUnchanged,DbObjectFilter.HideUnchanged)
        // run: execute comparison on specific dbObject(Run.Proc,Run.View,Run.Table,Run.ProcView,Run.ProcTable,Run.ViewTable,Run.All)
        string IndexPage = DbComparer.Compare(MyDbV1, MyDbV2, logger: myLogger, outputFolder: "customPath", makeChange: true, run: Run.Proc);
        Process.Start(new ProcessStartInfo { FileName = IndexPage, UseShellExecute = true });
    }
}

The HTML report is generated in the Diffinity-output folder by default.

API Overview

The Diffinity.Compare method accepts the following parameters:

  • sourceServer: A DbServer object representing the source database.
  • destinationServer: A DbServer object representing the destination database.
  • logger (optional): An ILogger instance for logging output. If not provided, a default logger is used.
  • outputFolder (optional): The directory where the generated HTML comparison reports will be saved. Defaults to a predefined Diffinity-output if not specified.`
  • makeChange: A ComparerAction enum that specifies whether to apply changes (ApplyChanges) or not (DoNotApplyChanges).
  • filter: A DbObjectFilter enum that determines whether to include unchanged procedures in the report (ShowUnchanged) or hide them (HideUnchanged).
  • run: A Run enum value indicating which database objects to compare, if not specified, default is All:
    • Proc: Compare only stored procedures.
    • View: Compare only views.
    • Table: Compare only tables.
    • ProcView: Compare stored procedures and views.
    • ProcTable: Compare stored procedures and tables.
    • ViewTable: Compare views and tables.
    • All: Compare procedures, views, and tables.

The core logic of the application is encapsulated in the Diffinity class and its helpers.

DbComparer class

This is the main class that orchestrates the comparison process.

  • Compare(DbServer sourceServer,DbServer destinationServer, ILogger? logger = null, string? outputFolder = null, ComparerAction? makeChange = ComparerAction.DoNotApplyChanges, DbObjectFilter? filter = DbObjectFilter.HideUnchanged,Run? run=Run.All):

    • Compares selected database objects based on the Run option and returns a generated HTML summary report.
  • CompareProcs(DbServer sourceServer, DbServer destinationServer,string outputFolder , ComparerAction makeChange, DbObjectFilter filter, Run run, HashSet<string> ignoredObjects):

    • Compares stored procedures.
  • CompareViews(DbServer sourceServer, DbServer destinationServer, string outputFolder, ComparerAction makeChange, DbObjectFilter filter, Run run, HashSet<string> ignoredObjects)

    • Compares SQL views.
  • CompareTables(DbServer sourceServer, DbServer destinationServer, string outputFolder, ComparerAction makeChange, DbObjectFilter filter, Run run, HashSet<string> ignoredObjects)

    • Compares table definitions.
  • Each Method:

    • Fetches all objects from the source and destination databases.
    • Uses hash-based body comparison to detect changes.
    • Optionally updates the destination procedure if differences are found.
    • Generates a summary HTML report and individual HTML files for each procedure.
    • Supports an optional .diffignore file to skip specific procedures, views, or tables during comparison.

HtmlHelper.HtmlReportWriter class

This class is responsible for generating the HTML reports.

  • WriteIndexSummary(...): Creates a general index HTML file linking to procedure, table, and view reports.
  • WriteSummaryReport(...): Generates a comparison summary page for a specific object type (e.g., procedures).
  • WriteBodyHtml(...): Writes a simple HTML page showing the full body of a procedure, view, or table.
  • DifferencesWriter(...): Generates a side-by-side diff view using the DiffPlex library highlighting differences between source and destination bodies.

ProcHelper, ViewHelper and TableHelper Namespaces

These namespaces contain classes responsible for fetching stored procedures, views, table schemas, and performing table comparison and update operations.

  • Fetcher: Retrieves object names and bodies or schema details from both source and destination databases.

    • GetProcedureNames(...), GetViewsNames(...), GetTablesNames(...): Fetch object names.
    • GetProcedureBody(...), GetViewBody(...), GetTableInfo(...): Fetch object bodies or schema details.
  • TableComparerAndUpdater: Compares table schemas between source and destination and updates the destination schema to match.

    • CompareTables(...): Compares column name, data type, nullability, max length, primary and foreign key flags between source and destination tables and optionally alters the destination schema to match.

DbObjectHandler class

This class handles logic for comparing and updating database objects (procedures, views, etc.).

  • AreBodiesEqual(...): Compares two SQL object bodies by normalizing and hashing them to determine structural equality.
  • AlterDbObject(...): Alters or creates a database object on the destination by executing either a CREATE or an ALTER version of the source body.
  • dbObjectResult (...) (nested class): Holds the result of comparing a source and destination object, including metadata and file paths.

.diffignore Support

The comparison process supports an optional .diffignore file to exclude specific database objects from comparison.

diffignore.txt should be in the same directory as the compiled .exe file.

Each line should contain the name of a stored procedure, view, or table to be ignored.

Lines beginning with # are treated as comments and ignored.

Matching is case-insensitive.

Example .diffignore:

# Ignore some procs and views
usp_GenerateReport
vw_ArchivedUsers

# Ignore a table
tbl_TempLogs

If present, any object listed in the .diffignore file will be skipped during the comparison and will not appear in the HTML reports.

For Contributors

If you're interested in contributing to Diffinity, visit the GitHub repository: 👉 https://github.com/HelenNow/Diffinity

Developed with 💖 in Lebanon

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.0.17 29 10/22/2025
1.0.16 24 10/22/2025
1.0.15 127 9/26/2025
1.0.14 119 9/26/2025
1.0.13 119 9/26/2025
1.0.12 109 9/26/2025
1.0.11 110 9/26/2025
1.0.10 118 9/26/2025