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());
});
相关推荐
EanoJiang6 小时前
CSharp_base
c#
xiaowu0808 小时前
C# 使用Windows API实现键盘钩子的类
windows·c#·计算机外设
十步杀一人_千里不留行11 小时前
面向 C# 初学者的完整教程
开发语言·c#
LcVong12 小时前
一篇文章学会开发第一个ASP.NET网页
后端·c#·asp.net·web
刘梦凡呀14 小时前
C# .NET Core 批量下载文件
windows·c#·.netcore
码观天工18 小时前
C#高性能开发之类型系统:从C# 7.0 到C# 14的类型系统演进全景
性能优化·c#·.net·memory·高性能·record·c#14·类型系统
程序员秘密基地18 小时前
基于c#,wpf,ef框架,sql server数据库,音乐播放器
sql·sqlserver·c#·.net·wpf
Zhen (Evan) Wang19 小时前
.NET 6 WPF 利用CefSharp.Wpf.NETCore显示PDF文件
.net·wpf·.netcore
钢铁男儿19 小时前
C#内存管理深度解析:值类型与引用类型全解析
前端·算法·c#
董先生_ad986ad20 小时前
C# 全局 Mutex 是否需使用 `Global\` 前缀
开发语言·c#