Ef Core花里胡哨系列(4) 多租户

Ef Core花里胡哨系列(4) 多租户

当然,我们要考虑设计问题,例如,切换Schema或者改变数据库时,Ef Core同样也会刷新改实体的缓存,所以,首次查询将会很慢,不适合大表。

基于Schema实现多租户

在我的上一篇博客中 [Ef Core花里胡哨系列(3) 动态修改实体对应的表(分表)、多租户] 中我们实现了如何分表,同理,我们可以用近似的方法来切换表的Schema,只需要一点很小的改动。

csharp 复制代码
public class SampleDbContext(DbContextOptions<SampleDbContext> options)
    : DbContext(options)
{
    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<User>().ToTable($"User{DateTime.Now.ToString("yyyyMM")}", YourSchema);

        base.OnModelCreating(modelBuilder);
    }
}

基于多库实现多租户

实现切换数据库我们将会采用的是Interceptor拦截器来实现。

建议租户相关的操作采用单独的DbContext和系统表区分开。

csharp 复制代码
public class TenantDbConnectionInterceptor<T> : DbConnectionInterceptor
{
    public TenantDbConnectionInterceptor()
    {
    }

    public override InterceptionResult ConnectionOpening(DbConnection connection, ConnectionEventData eventData, InterceptionResult result)
    {
        connection.ConnectionString = "对应租户的连接字符串";

        return base.ConnectionOpening(connection, eventData, result);
    }

    public override ValueTask<InterceptionResult> ConnectionOpeningAsync(DbConnection connection, ConnectionEventData eventData, InterceptionResult result, CancellationToken cancellationToken = default)
    {
        connection.ConnectionString = "对应租户的连接字符串";

        return base.ConnectionOpeningAsync(connection, eventData, result, cancellationToken);
    }
}

使用拦截器

csharp 复制代码
services.AddDbContext<DynamicDbContext>(opts =>
{
    opts.AddInterceptors(new TenantDbConnectionInterceptor());
});
相关推荐
时光追逐者1 小时前
一个使用 WPF 开发的 Diagram 画板工具(包含流程图FlowChart,思维导图MindEditor)
c#·.net·wpf·流程图
我是唐青枫1 小时前
C#.NET FluentValidation 全面解析:优雅实现对象验证
c#·.net
YuanlongWang2 小时前
C# 设计模式——工厂模式
开发语言·设计模式·c#
时光追逐者2 小时前
C#/.NET/.NET Core技术前沿周刊 | 第 58 期(2025年10.13-10.19)
微软·开源·c#·.net·.netcore
躺平的赶海人4 小时前
C# Dictionary 线程安全指南:多线程下操作 Dictionary<string, DateTime> 的加锁策略
java·安全·c#
张人玉6 小时前
C#WPF如何实现登录页面跳转
ui·c#·wpf
张人玉6 小时前
C#WPF如何跳转页面
笔记·ui·c#·wpf
future_studio7 小时前
聊聊 Unity(小白专享、C# 小程序 之 自动更新)
unity·小程序·c#
主宰者7 小时前
【C#】.NET Framework 4.8环境下使用Sqlite的问题总结
sqlite·c#·.net
心疼你的一切8 小时前
Unity开发利器:ScriptableObject的数据容器设计与内存优化原理
microsoft·unity·c#·游戏引擎