Chd.Library.Migrations
                              
                            
                                8.5.2
                            
                        
                    See the version list below for details.
dotnet add package Chd.Library.Migrations --version 8.5.2
NuGet\Install-Package Chd.Library.Migrations -Version 8.5.2
<PackageReference Include="Chd.Library.Migrations" Version="8.5.2" />
<PackageVersion Include="Chd.Library.Migrations" Version="8.5.2" />
<PackageReference Include="Chd.Library.Migrations" />
paket add Chd.Library.Migrations --version 8.5.2
#r "nuget: Chd.Library.Migrations, 8.5.2"
#:package Chd.Library.Migrations@8.5.2
#addin nuget:?package=Chd.Library.Migrations&version=8.5.2
#tool nuget:?package=Chd.Library.Migrations&version=8.5.2
Migration library for .Net Core
Chd (cleverly handle difficulty) library helps you cleverly handle difficulty, writing code fastly and do your application stable.
📝 Table of Contents
- About
- Getting Started
- Injection PostgreSQL Migration Into The Project
- Injection Oracle Migration Into The Project
- Injection Mssql Migration Into The Project
- Injection SqlLite Migration Into The Project
- Apsettings Configurations
- Adding Schema Migration
- Adding Data Migration
- Usage
- Authors
- Acknowledgments
🧐 About
Migrations are a structured way to alter your database schema and are an alternative to creating lots of sql scripts that have to be run manually by every developer involved.
🏁 Getting Started
This migrations using a table called VersionInfo. Each record in this table contains a unique VersionId. Migration attribute have two parameters. First one is version number and second one is author name.
The library searches in the namespace of the class you enter when injected. It finding classes which inherited "Migration" class in this namespace. It runs the Up method of the classes which have a version number greater than the version number in the VersionInfo table. It runs the Down method of the classes which have a version number less than the version number in the VersionInfo table.
Prerequisites
You must use .net core 9.0 or higher
💉 Injection PostgreSQL Migration Into The Project
In your program.cs file, you should add the code below.
   var builder = WebApplication.CreateBuilder(args);
   ....
   .... 
   builder.Services.AddMigration<Program>(DatabaseType.PostgreSQL,"PostgreSQLTest");
💉 Injection Oracle Migration Into The Project
In your program.cs file, you should add the code below.
   var builder = WebApplication.CreateBuilder(args);
   ....
   .... 
   builder.Services.AddMigration<Program>(DatabaseType.Oracle,"OracleTest"); 
💉 Injection Mssql Migration Into The Project
In your program.cs file, you should add the code below.
   var builder = WebApplication.CreateBuilder(args);
   ....
   ....
   builder.Services.AddMigration<Program>(DatabaseType.MsSQL,"MsSQLTest"); 
💉 Injection SqlLite Migration Into The Project
In your program.cs file, you should add the code below.
   var builder = WebApplication.CreateBuilder(args);
   ....
   ....
   builder.Services.AddMigration<Program>(DatabaseType.SQLite,"SQLiteTest");
⚙️ Apsettings Configurations
You must add code below in appsettings.json
  "ConnectionStrings": {
    "SQLiteTest": "Data Source=mydb.db;",
    "OracleTest":"Data Source=MyOracleDB;User Id=myUsername;Password=myPassword;Integrated Security=no;",
    "MsSQLTest": "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;",
    "PostgreSQLTest": "IncludeErrorDetails = true;User ID=postgres;Password=postgres_admin_password;Server=localhost;Port=5432;Database=my_db;Integrated Security=true;Pooling=true;",
  }
🛠️ Adding Schema Migration
We make a sample schema migration for you. This migration creates a table called "student" and adds some columns to it. If you run the application, you can see tables whice you write in migration codes on the database.
We must give version of beginning 1 to 1000000 numbers to schema changes, because of having to separate schema changes and data changes. Then we give version id numbers after 1000000 to data changes.
We will write this migration for PostgreSQL word syntax. If you want to use another database, you can change the word syntax in the migration code.
    [Migration(1, "Mehmet Yoldaş")]
    public class ShemaChanges_V1 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Create.Table("student").WithIdColumn().
            WithColumn("first_name").AsString().
            WithColumn("last_name").AsString().
            WithColumn("user_name").AsString().
            WithColumn("birth_date").AsDate();
        }
    }
    [Migration(1, "Mehmet Yoldaş")]
    public class ShemaChanges_V1 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Create.Table("student").WithIdColumn().
            WithColumn("first_name").AsString().
            WithColumn("last_name").AsString().
            WithColumn("user_name").AsString().
            WithColumn("birth_date").AsDate();
        }
    }
    [Migration(2, "Mehmet Yoldaş")]
    public class ShemaChanges_V2 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Create.Table("course").WithIdColumn().
            WithColumn("course_id").AsString().
            WithColumn("name").AsString();
        }
    }
    [Migration(3, "Mehmet Yoldaş")]
    public class ShemaChanges_V3 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Create.Table("student_course").WithIdColumn().
            WithColumn("course_id").AsInt32().ForeignKey("course", "id").
            WithColumn("student_id").AsInt32().ForeignKey("student", "id");
        }
    }
    [Migration(6, "Mehmet Yoldaş")]
    public class ShemaChanges_V6 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Create.Table("country").WithIdColumn().
            WithColumn("name").AsInt32();
            Create.Table("city").WithIdColumn().
            WithColumn("country_id").AsInt32().ForeignKey("country", "id").
            WithColumn("name").AsInt32();
            Create.Table("town").WithIdColumn().
            WithColumn("city_id").AsInt32().ForeignKey("city", "id").
            WithColumn("name").AsInt32();
            Create.Table("street").WithIdColumn().
            WithColumn("town_id").AsInt32().ForeignKey("town", "id").
            WithColumn("name").AsInt32();
        }
    }
    [Migration(7, "Mehmet Yoldaş")]
    public class ShemaChanges_V7 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Create.Table("student_country").WithIdColumn().
            WithColumn("student_id").AsInt32().ForeignKey("student", "id").
            WithColumn("country_id").AsInt32().ForeignKey("country", "id");
        }
    }
    [Migration(4, "Mehmet Yoldaş")]
    public class ShemaChanges_V4 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Create.Table("hold").WithIdColumn().
            WithColumn("hold_status").AsInt32().
            WithColumn("description").AsString();
        }
    }
    [Migration(5, "Mehmet Yoldaş")]
    public class ShemaChanges_V5 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Create.Table("hold_v2_status_type").WithIdColumn().
            WithColumn("name").AsString().
            WithColumn("description").AsString();
            Create.Table("hold_v2").WithIdColumn().
            WithColumn("description").AsString();
            Create.Table("hold_v2_defination").WithIdColumn().
            WithColumn("hold_status_type_id").AsInt32().ForeignKey("hold_v2_status_type", "id").
            WithColumn("hold_id").AsInt32().ForeignKey("hold_v2", "id");
        }
    }
    [Migration(6, "Mehmet Yoldaş")]
    public class DataChanges_V6 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
         Alter.Table("student").AddColumn("email").AsString();
        }
    }
📋 Adding Data Migration
We make a sample data migration for you. This migration adds some data to the table called "student". If you run the application, you can see data which you write in migration codes on the database.
We give version id numbers after 1000000 to data changes.
    [Migration(1000001, "Mehmet Yoldaş")]
    public class DataChanges_V1 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Insert.Into("student").Row(new { first_name = "Mehmet", last_name = "Yoldaş", user_name = "mehmetyoldas", birth_date = DateTime.Now });
            Insert.Into("student").Row(new { first_name = "Ali", last_name = "Yılmaz", user_name = "aliyilmaz", birth_date = DateTime.Now });
            Insert.Into("student").Row(new { first_name = "Ayşe", last_name = "Kaya", user_name = "aysekaya", birth_date = DateTime.Now });
            Insert.Into("student").Row(new { first_name = "Fatma", last_name = "Kara", user_name = "fatmakara", birth_date = DateTime.Now });
        }
    }
    [Migration(1000002, "Mehmet Yoldaş")]
    public class DataChanges_V2 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
            Insert.Into("course").Row(new { course_id = "1", name = "Math" });
            Insert.Into("course").Row(new { course_id = "2", name = "Science" });
            Insert.Into("course").Row(new { course_id = "3", name = "History" });
            Insert.Into("course").Row(new { course_id = "4", name = "Geography" });
        }
    }
    [Migration(1000003, "Mehmet Yoldaş")]
    public class DataChanges_V3 : Migration
    {
        public override void Down()
        {
        }
        public override void Up()
        {
           Insert.Into("student_course").Row(new { course_id = 1, student_id = 1 });
           Insert.Into("student_course").Row(new { course_id = 2, student_id = 1 });
           Insert.Into("student_course").Row(new { course_id = 3, student_id = 1 });
           Insert.Into("student_course").Row(new { course_id = 4, student_id = 1 });
           Insert.Into("student_course").Row(new { course_id = 1, student_id = 2 });
           Insert.Into("student_course").Row(new { course_id = 2, student_id = 2 });
           Insert.Into("student_course").Row(new { course_id = 3, student_id = 2 });
           Insert.Into("student_course").Row(new { course_id = 4, student_id = 2 });
        }
    }
After running application, you can see sample data in the database.
🎈 Usage
Just run the application to get the migrations work done. The library will automatically create the tables and columns you have written in the migration code. And it will add the data you have written in the data migration code to the tables.
✍️ Authors
- Mehmet Yoldaş - Linkedin
See also the list of contributors who participated in this project.
🎉 Acknowledgements
Thank you for using my library.
| Product | Versions 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. | 
- 
                                                    net8.0- Chd.Library.Core (>= 8.5.2)
- FluentMigrator.Runner (>= 3.3.2)
- Microsoft.AspNetCore.Http.Abstractions (>= 2.2.0)
- Microsoft.Data.Sqlite (>= 8.0.1)
- Microsoft.EntityFrameworkCore.Design (>= 8.0.1)
- Microsoft.EntityFrameworkCore.Sqlite (>= 8.0.1)
- Microsoft.EntityFrameworkCore.Sqlite.Core (>= 8.0.1)
- Microsoft.EntityFrameworkCore.SqlServer (>= 8.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 | 
|---|---|---|
| 9.0.7 | 176 | 1/30/2025 | 
| 9.0.6 | 173 | 1/1/2025 | 
| 9.0.5 | 140 | 12/30/2024 | 
| 9.0.4 | 149 | 12/29/2024 | 
| 8.5.4 | 170 | 8/17/2025 | 
| 8.5.3 | 154 | 8/3/2025 | 
| 8.5.2 | 144 | 7/31/2025 | 
| 8.5.1 | 571 | 7/23/2025 | 
| 8.0.9 | 161 | 12/23/2024 | 
| 8.0.8 | 153 | 12/23/2024 | 
| 8.0.3 | 454 | 2/3/2024 | 
| 8.0.2 | 408 | 2/3/2024 | 
| 8.0.1 | 428 | 2/3/2024 | 
| 8.0.0 | 423 | 1/30/2024 | 
| 7.4.5 | 592 | 9/4/2023 | 
| 7.4.4 | 563 | 9/4/2023 | 
| 7.4.3 | 587 | 9/4/2023 | 
| 7.4.2 | 658 | 9/4/2023 | 
| 7.4.1 | 638 | 8/25/2023 | 
| 7.4.0 | 654 | 8/18/2023 | 
| 7.3.3 | 816 | 8/9/2023 | 
| 1.3.3 | 799 | 5/28/2023 | 
| 1.3.2 | 726 | 5/11/2023 | 
| 1.3.1 | 751 | 4/28/2023 | 
| 1.3.0 | 794 | 4/28/2023 | 
| 1.2.9 | 844 | 4/24/2023 | 
| 1.2.8 | 729 | 4/20/2023 | 
| 1.2.7 | 1,012 | 1/30/2023 | 
| 1.1.9 | 2,482 | 1/30/2023 |