ADatabaseMigrator.SqlServer
0.1.0
dotnet add package ADatabaseMigrator.SqlServer --version 0.1.0
NuGet\Install-Package ADatabaseMigrator.SqlServer -Version 0.1.0
<PackageReference Include="ADatabaseMigrator.SqlServer" Version="0.1.0" />
paket add ADatabaseMigrator.SqlServer --version 0.1.0
#r "nuget: ADatabaseMigrator.SqlServer, 0.1.0"
// Install ADatabaseMigrator.SqlServer as a Cake Addin #addin nuget:?package=ADatabaseMigrator.SqlServer&version=0.1.0 // Install ADatabaseMigrator.SqlServer as a Cake Tool #tool nuget:?package=ADatabaseMigrator.SqlServer&version=0.1.0
ADatabaseMigrator - An Appeasing Database Migrator
A small and flexible package you can use to run database migration scripts.
<img src="./icon.png" alt="ADatabaseMigrator Icon" width="50%" height="50%">
Getting started
- Create a class project to contain your migrations
- Place your migrations in a file structure like this:
\Scripts\Migrations\001.00.00\001_MyFirstMigration.sql \Scripts\Migrations\001.00.00\002_MySecondMigration.sql \Scripts\RunAlways\001_RunLog_.sql \Scripts\RunIfChanged\001_MyFirstView_.sql
- Add this
ItemGroup
to thecsproj
file to configure the files in the script folder become embedded resources in the assembly<ItemGroup> <EmbeddedResource Include="Scripts\**\*.sql" /> </ItemGroup>
- Add a
nuget
reference toADatabaseMigrator
- Create and invoke a migrator like so:
Some things to note about the configuration embedded resource script loader configuration here:var migrator = new Migrator( scriptLoader: new EmbeddedResourceScriptLoader(new MD5ScriptHasher(), config => config .UsingAssemblyFromType<ScriptLoaderTests>() .AddNamespaces<VersionFromPathVersionLoader>(MigrationScriptRunType.RunOnce, "Scripts.Migrations") .AddNamespaces<VersionFromAssemblyVersionLoader>(MigrationScriptRunType.RunIfChanged, "Scripts.RunIfChanged") .AddNamespaces<VersionFromAssemblyVersionLoader>(MigrationScriptRunType.RunAlways, "Scripts.RunAlways")), journalManager: new MigrationScriptJournalManager(connection), scriptRunner: new MigrationScriptRunner(connection)); await migrator.Migrate();
UsingAssemblyFromType<ScriptLoaderTests>()
specifies an assembly from which we can configure subsequent namespaces to fetch migrations from. We can call this method multiple times if we have migrations from multiple assemblies to load.AddNamespaces<VersionFromPathVersionLoader>(MigrationScriptRunType.RunOnce, "Scripts.Migrations")
, specifies that we want to load scripts from inside the folderScripts\Migrations
, we want them to be run only once and we want to extract the version number from the the path.AddNamespaces<VersionFromAssemblyVersionLoader>(MigrationScriptRunType.RunIfChanged, "Scripts.RunIfChanged")
specifies we want to load scripts from inside the folderScripts\RunIfChanged
, we want them to be run every time they are changed (when the hash of the file changes) and we use version number from the previously specified assembly.AddNamespaces<VersionFromAssemblyVersionLoader>(MigrationScriptRunType.RunAlways, "Scripts.RunAlways")
specifies that we want to load scripts from inside the folderScripts\RunAlways
, we want them to be run every time we run the migrator and we use version number from the previously specified assembly.- Note that the order of the
AddNamespaces
invocations specifies the execution order, so in our example the Migrations are executed first, then RunIfChanged and last RunAlways. Within a namespace the migrations found are executed first in order of version, then in order of embedded resource name. This means that if you want your scripts to run in a specific order, you have full control over this by adding namespaces in the order you want.
Packages and Contents
ADatabaseMigrator
Contains the Migrator
class which you instantiate to run your migrations. The class needs 3 things in order to be instantiated:
- A script loader, that can find the script files you want to run.
- A journal manager, that can load already executed scripts from the database.
- A script runner that can execute scripts.
You can write your own script loaders, journal managers and scripts runners, but the package comes with some predefined classes to use or extend:
EmbeddedResourceScriptLoader
is a script loader that loads scripts from embedded resources in one or more assemblies. This class also requires a script hasher in order to create a unique hash for the loaded scripts, theMD5ScriptHasher
is provided as a default script hasher.MigrationScriptJournalManager
that loads executed scripts from a table namedSchemaVersionJournal
.MigrationScriptRunner
that can execute scripts given a connection (and an optional transaction if you want the whole migration to be executed in a provided transaction).
ADatabaseFixture.SqlServer
Contains SqlServerMigrationScriptRunner
which you can use as a script runner instead of MigrationScriptRunner
if you need batch support (like if your scripts contains GO
statements for instance).
Compatibility with GalacticWasteManagement
ADatabaseMigrator
is inspired by, and can be somewhat made compatible with Galactic-Waste-Management, which has been deprecated. By swapping out MigrationScriptJournalManager
in the example above for GalacticWasteMigrationScriptJournalManager
, you should be able to run migrations compatible with what GWM calls LiveField
.
This means that we map the GWM
run type Migration
to ADatabaseMigrator
run type RunOnce
. GWM
has support for more run types like Seed
, vNext
and more, as well as creating custom run types. ADatabaseMigrator does not have support for these out of the box, but you could create custom mappings by creating your own class that inherits from GalacticWasteMigrationScriptJournalManager
and override the ParseGalacticWasteRunType
method.
Note however that ADatabaseMigrator
is a more focused tool than GWM
and will never attempt to drop or restore the database. If you have the need for such orchestrations, I would suggest implementing this yourself, where running ADatabaseMigrator
migrations could be part of the overall orchestration.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- ADatabaseMigrator (>= 0.1.0)
- Microsoft.SqlServer.Management.SqlParser (>= 172.0.1)
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 |
---|---|---|
0.1.0 | 308 | 3/22/2024 |