Aiursoft.DbTools.SqlServer 9.0.25
DBTools
DbTools are Aiursoft's common database tools. It simplifies the process of registering DbContext and updating database. So your application can easily switch from different database types without editing the code.
How to install
Run the following command to install Aiursoft.DbTools.Switchable to your ASP.NET Core project from nuget.org:
dotnet add package Aiursoft.DbTools.Switchable
Run the following command to install Aiursoft.DbTools.InMemory to your database implementation project from nuget.org:
dotnet add package Aiursoft.DbTools.InMemory
All database implementation projects must reference a single AbstractDb project. And you need to define and use the abstract class YourDbContext in it.
Make sure your project dependency is as follows:
---
title: Project dependency diagram
---
stateDiagram-v2
    Aiursoft.DbTools.InMemory --> Aiursoft.DbTools
    Aiursoft.DbTools.Sqlite --> Aiursoft.DbTools
    Aiursoft.DbTools.MySql --> Aiursoft.DbTools
    Aiursoft.DbTools.PostgreSql --> Aiursoft.DbTools
    Aiursoft.DbTools.Switchable --> Aiursoft.DbTools
    Demo.Entities --> Aiursoft.DbTools
    Demo.Sqlite --> Aiursoft.DbTools.Sqlite
    Demo.Sqlite --> Demo.Entities
    Demo.MySql --> Aiursoft.DbTools.MySql
    Demo.MySql --> Demo.Entities
    Demo.PostgreSql --> Aiursoft.DbTools.PostgreSql
    Demo.PostgreSql --> Demo.Entities
    Demo.InMemory --> Aiursoft.DbTools.InMemory
    Demo.InMemory --> Demo.Entities
    Demo.WebApp --> Aiursoft.DbTools.Switchable
    Demo.WebApp --> Demo.InMemory
    Demo.WebApp --> Demo.MySql
    Demo.WebApp --> Demo.Sqlite
    Demo.WebApp --> Demo.PostgreSql
    Aiursoft.DbTools.SqlServer --> Aiursoft.DbTools
Usage
In your startup.cs:
// In your Web project
public void ConfigureServices(IConfiguration configuration, IWebHostEnvironment environment, IServiceCollection services)
{
    var (connectionString, dbType, allowCache) = configuration.GetDbSettings();
    services.AddSwitchableRelationalDatabase(
        dbType: EntryExtends.IsInUnitTests() ? "InMemory": dbType,
        connectionString: connectionString,
        supportedDbs:
        [
            // These comes from your database implementation projects.
            new MySqlSupportedDb(allowCache: allowCache, splitQuery: false),
            new SqliteSupportedDb(allowCache: allowCache, splitQuery: true),
            new PostgreSqlSupportedDb(allowCache: allowCache, splitQuery: false),
            new InMemorySupportedDb()
        ]);
    services
        .AddControllersWithViews()
        .AddApplicationPart(typeof(Startup).Assembly);
}
In your appsettings.json:
{
    "ConnectionStrings": {
        "AllowCache": "True",
        "DbType": "Sqlite",
        "DefaultConnection": "DataSource=app.db;Cache=Shared"
    }
}
Or:
{
  // sudo docker run -d --name db -e MYSQL_RANDOM_ROOT_PASSWORD=true -e MYSQL_DATABASE=kahla -e MYSQL_USER=kahla -e MYSQL_PASSWORD=kahla_password -p 3306:3306 mysql
  "ConnectionStrings": {
    "AllowCache": "True",
    "DbType": "MySql",
    "DefaultConnection": "Server=localhost;Database=kahla;Uid=kahla;Pwd=kahla_password;"
  }
}
Or:
{
  // sudo docker run --name kahla-postgres -e POSTGRES_DB=kahla -e POSTGRES_USER=kahla -e POSTGRES_PASSWORD=kahla_password -p 5432:5432 -d postgres:latest
  "ConnectionStrings": {
    "AllowCache": "True",
    "DbType": "PostgreSql",
    "DefaultConnection": "Server=localhost;Database=kahla;Uid=kahla;Pwd=kahla_password;"
  }
}
Or:
{
  "ConnectionStrings": {
    "AllowCache": "False",
    "DbType": "InMemory"
  }
}
Simple, isn't it?
Your database project need to be different with your web project, you need the following command to generate migrations:
cd ./Demo.MySql
dotnet ef migrations add Init --context "MySqlContext" -s ../Demo.WebApp/Demo.WebApp.csproj
cd ..
cd ./Demo.Sqlite
dotnet ef migrations add Init --context "SqliteContext" -s ../Demo.WebApp/Demo.WebApp.csproj
cd ..
cd ./Demo.PostgreSql
dotnet ef migrations add Init --context "PostgreSqlContext" -s ../Demo.WebApp/Demo.WebApp.csproj
cd ..
For more usage, please check the Demo app in the demos folder!
How to contribute
There are many ways to contribute to the project: logging bugs, submitting pull requests, reporting issues, and creating suggestions.
Even if you with push rights on the repository, you should create a personal fork and create feature branches there when you need them. This keeps the main repository clean and your workflow cruft out of sight.
We're also interested in your feedback on the future of this project. You can submit a suggestion or feature request through the issue tracker. To make this process more effective, we're asking that these include more information to help define them more clearly.
Showing the top 20 packages that depend on Aiursoft.DbTools.SqlServer.
| Packages | 
|---|
| Aiursoft.SDK The base class, tools and extends for Aiursoft web apps. | 
.NET 9.0
- Aiursoft.DbTools (>= 9.0.20)
- EFCoreSecondLevelCacheInterceptor.MemoryCache (>= 5.3.3)
- Microsoft.EntityFrameworkCore.SqlServer (>= 9.0.10)
| Version | Last updated | 
|---|---|
| 9.0.25 | 10/20/2025 | 
| 9.0.24 | 9/12/2025 | 
| 9.0.23 | 9/6/2025 | 
| 9.0.22 | 9/4/2025 | 
| 9.0.21 | 8/5/2025 | 
| 9.0.20 | 7/9/2025 | 
| 9.0.19 | 6/30/2025 | 
| 9.0.18 | 6/11/2025 | 
| 9.0.17 | 6/1/2025 | 
| 9.0.16 | 5/1/2025 | 
| 9.0.15 | 4/16/2025 | 
| 9.0.14 | 4/9/2025 | 
| 9.0.13 | 4/7/2025 | 
| 9.0.12 | 3/12/2025 | 
| 9.0.11 | 5/3/2025 | 
| 9.0.10 | 5/3/2025 | 
| 9.0.9 | 5/29/2025 | 
| 9.0.8 | 6/11/2025 | 
| 9.0.7 | 5/4/2025 | 
| 9.0.6 | 6/9/2025 | 
| 9.0.5 | 3/20/2025 | 
| 9.0.4 | 5/7/2025 | 
| 9.0.3 | 4/7/2025 | 
| 9.0.1 | 6/6/2025 | 
| 9.0.0 | 5/25/2025 | 
| 8.0.28 | 5/3/2025 | 
| 8.0.27 | 5/3/2025 | 
| 8.0.26 | 5/3/2025 | 
| 8.0.24 | 3/30/2025 | 
| 8.0.23 | 5/3/2025 | 
| 8.0.22 | 5/3/2025 | 
| 8.0.21 | 5/3/2025 | 
| 8.0.20 | 5/3/2025 | 
| 8.0.19 | 5/3/2025 | 
| 8.0.18 | 5/3/2025 | 
| 8.0.17 | 5/3/2025 | 
| 8.0.16 | 5/3/2025 | 
| 8.0.15 | 5/3/2025 | 
| 8.0.14 | 4/29/2025 | 
| 8.0.13 | 5/3/2025 | 
| 8.0.12 | 5/3/2025 | 
| 8.0.11 | 5/3/2025 | 
| 8.0.10 | 5/3/2025 | 
| 8.0.9 | 4/16/2025 | 
| 8.0.8 | 5/11/2025 | 
| 8.0.7 | 6/9/2025 | 
| 8.0.6 | 5/11/2025 | 
| 8.0.5 | 5/4/2025 | 
| 8.0.4 | 6/9/2025 | 
| 8.0.3 | 6/5/2025 | 
| 8.0.2 | 4/9/2025 | 
| 8.0.1 | 6/9/2025 | 
| 8.0.0 | 4/7/2025 | 
| 7.0.25 | 5/3/2025 | 
| 7.0.24 | 5/3/2025 | 
| 7.0.23 | 5/3/2025 | 
| 7.0.22 | 5/3/2025 | 
| 7.0.21 | 5/3/2025 | 
| 7.0.20 | 5/3/2025 | 
| 7.0.19 | 5/3/2025 | 
| 7.0.18 | 5/3/2025 | 
| 7.0.17 | 4/1/2025 | 
| 7.0.16 | 3/12/2025 | 
| 7.0.15 | 5/3/2025 | 
| 7.0.14 | 3/30/2025 | 
| 7.0.13 | 5/3/2025 | 
| 7.0.12 | 5/3/2025 | 
| 7.0.11 | 5/3/2025 | 
| 7.0.10 | 5/3/2025 | 
| 7.0.9 | 6/15/2025 | 
| 7.0.8 | 6/2/2025 | 
| 7.0.7 | 6/6/2025 | 
| 7.0.6 | 6/6/2025 | 
| 7.0.5 | 6/5/2025 | 
| 7.0.4 | 6/5/2025 | 
| 7.0.3 | 4/18/2025 | 
| 7.0.2 | 5/5/2025 | 
| 7.0.1 | 3/26/2025 | 
| 7.0.0 | 5/4/2025 | 
| 6.0.32 | 5/3/2025 | 
| 6.0.31 | 5/3/2025 | 
| 6.0.30 | 3/23/2025 | 
| 6.0.29 | 5/3/2025 |