Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/adamfoneil/modelsync
A C# model class and database schema comparison, SQL diff scripting library
https://github.com/adamfoneil/modelsync
schema-diff sql-generator sql-script
Last synced: about 1 month ago
JSON representation
A C# model class and database schema comparison, SQL diff scripting library
- Host: GitHub
- URL: https://github.com/adamfoneil/modelsync
- Owner: adamfoneil
- License: mit
- Created: 2020-02-15T10:42:52.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-01-24T00:56:54.000Z (12 months ago)
- Last Synced: 2024-11-01T01:03:54.347Z (2 months ago)
- Topics: schema-diff, sql-generator, sql-script
- Language: C#
- Homepage:
- Size: 506 KB
- Stars: 6
- Watchers: 2
- Forks: 2
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
**Note** I'm not really updating this anymore. Please see my new iteration of this [Ensync](https://github.com/adamfoneil/Ensync).
---
[![Nuget](https://img.shields.io/nuget/v/AO.ModelSync.Library)](https://www.nuget.org/packages/AO.ModelSync.Library/)
This is a library for generating and executing SQL diff merge scripts. There are two use cases:
- Generate diff script by comparing an assembly or database with another database using [DataModel.Compare](https://github.com/adamosoftware/ModelSync/blob/master/ModelSync.Library/Models/DataModel_Compare.cs#L8). This functionality powers my [ModelSync](https://aosoftware.net/modelsync/) app, which is itself open source: [ModelSync.WinForms](https://github.com/adamfoneil/ModelSync.WinForms).
- Create empty tables from C# model classes with [DataModel.CreateTablesAsync](https://github.com/adamosoftware/ModelSync/blob/master/ModelSync.Library/Models/DataModel_Create.cs#L39).
Nuget package: **AO.ModelSync.Library**
# DataModel.Compare
Use `DataModel.Compare` to generate a diff script from an assembly or database to another database. This example is adapted from this [test](https://github.com/adamosoftware/ModelSync/blob/master/Testing/ModelComparison.cs#L429):
```csharp
using (var cn = GetConnection())
{
var sourceModel = DataModel.FromAssembly(@"c:\users\adam\repos\whatever.dll");
var destModel = await DataModel.FromSqlServerAsync(cn);
var diff = DataModel.Compare(sourceModel, destModel);
string script = new SqlServerDialect().FormatScript(diff);
Debug.Print(script);
}
```
Output might look like:
```sql
ALTER TABLE [child1] DROP CONSTRAINT [FK_child1_parentId]
GO
ALTER TABLE [child2] DROP CONSTRAINT [FK_child2_parentId]
GO
DROP TABLE [parent]
```
Source links: [DataModel.FromAssembly](https://github.com/adamosoftware/ModelSync/blob/master/ModelSync.Library/Models/DataModel.cs#L34), [DataModel.FromSqlServerAsync](https://github.com/adamosoftware/ModelSync/blob/master/ModelSync.Library/Models/DataModel.cs#L28)# DataModel.CreateTablesAsync
Use `DataModel.CreateTablesAsync` to create empty tables as part of a component initialization. For example in my [WorkTracker](https://github.com/adamosoftware/WorkTracker/blob/master/WorkTracker.Library/JobTracker.cs#L32) project, I create tables from a couple model classes [Job](https://github.com/adamosoftware/WorkTracker/blob/master/WorkTracker.Library/Models/Job.cs) and [Error](https://github.com/adamosoftware/WorkTracker/blob/master/WorkTracker.Library/Models/Error.cs). This `CreateTableAsync` overload accepts a `Func` through which your database connection is opened.```csharp
await DataModel.CreateTablesAsync(new[]
{
typeof(Job),
typeof(Error)
}, GetConnection);
```
I have another example along these lines in my Dapper.CX [Change Tracking](https://github.com/adamosoftware/Dapper.CX/wiki/Using-ChangeTracker) stuff, which [creates a couple tables](https://github.com/adamfoneil/Dapper.CX/blob/master/Dapper.CX.ChangeTracking/LoggedChangeTracker.cs#L121-L125) from some model classes.# Background
This is a reboot of my [SchemaSync](https://github.com/adamosoftware/SchemaSync) project, which had run into [issues](https://github.com/adamosoftware/SchemaSync/issues) I couldn't figure out.The intent is the same: compare data models to generate a SQL diff merge script. The difference from other database diff apps out there is that this can treat .NET assemblies as data sources -- so that you can merge from C# model classes as well as to and from SQL Server databases. This enables you to use a single tool to migrate model changes end-to-end in your application.
The ultimate goal is to provide a GUI app for use as a Visual Studio "external tool" as an alternative to Entity Framework migrations. I never made peace with EF migrations, and have dabbled in alternative approaches for a long time. I believe it's a better dev experience to merge model classes on demand with a GUI tool rather than interrupting flow to write migrations. Besides being an interruption, migrations have their own administrative complications that, like I say, I never found acceptable.
That said, my approach to model sync works best with a shared development database rather than local database copies. This is because the diff scripting is not always perfect, so a little bit of manual intervention may be needed sometimes. By merging to a shared dev database, you minimize the "finesse" needed to accomplish some merges.
Things different this time around:
- No MySQL support. This will target SQL Server only for now. There are base abstract classes I can build upon later to target other platforms if I get around to it.
- No empty table rebuilds. A lot of the earlier [issues](https://github.com/adamosoftware/SchemaSync/issues) I ran into before stemmed from dropping and re-creating empty tables in order to add columns. I did that because I wanted the table column order to match the order of properties in your source files as much as possible. But a lot complexity creeps in from this use case. So, this time around there won't be any table drops and rebuilds as part of the diff algorithm. Table rebuilds will be a standalone feature you can invoke periodically -- distinct from a diff merge -- when you want to align table column order with property order.
- No seed data support initially. Maybe later.
- A smaller dependency footprint. I had a lot of type load exceptions in my old GUI app due to dependencies getting out of date with my [Postulate](https://github.com/adamosoftware/Postulate) library. The app would have one version of Postulate, while projects might have a different version. I've refactored those dependencies into a new, smaller, more stable project called [DbSchema.Attributes](https://github.com/adamosoftware/DbSchema.Attributes). I'm hoping this will clear up type load exceptions in the app as well as be more attractive to dependency-concscious devs. This is all to say that ModelSync is not pure POCO when it comes to inferring metadata like unique constraints and foreign keys. I'll have more to say about developing model classes for ModelSync compatibility.The forthcoming GUI tool will be closed-source, but the library that powers it, this repo, will remain open source.