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());
});
相关推荐
程序员敲代码吗5 分钟前
如何通过命令行启动COMSOL的参数化、批处理和集群扫描
java·c#·bash
缺点内向2 小时前
C#: 告别繁琐!轻松移除Word文档中的文本与图片水印
c#·自动化·word·.net
喵叔哟3 小时前
06-ASPNETCore-WebAPI开发
服务器·后端·c#
2501_930707783 小时前
使用 C# .NET 从 PowerPoint 演示文稿中提取背景图片
c#·powerpoint·.net
初级代码游戏3 小时前
套路化编程 C# winform 自适应缩放布局
开发语言·c#·winform·自动布局·自动缩放
大空大地20265 小时前
流程控制语句--switch多分支语句使用、while循环语句的使用、do...while语句、for循环
c#
kylezhao20196 小时前
C#序列化与反序列化详细讲解与应用
c#
JQLvopkk6 小时前
C# 实践AI :Visual Studio + VSCode 组合方案
人工智能·c#·visual studio
故事不长丨6 小时前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
kingwebo'sZone7 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word