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());
});
相关推荐
成都易yisdong14 小时前
纬地、鸿业、海地、CASS等横断面数据互转工具V3.2——测绘与道路设计人员的效率神器
c#·visual studio code
AIKZX18 小时前
西门子博途 TIA Portal v18 中文版图文安装教程(超级详细)附下载链接
开发语言·c#·编辑器·idea
xiaoshuaishuai820 小时前
C# 数字资源分发
开发语言·c#
格林威21 小时前
面阵相机 vs 线阵相机:堡盟与Basler选型差异全解析 +C# 实战演示
开发语言·人工智能·数码相机·计算机视觉·c#·视觉检测·工业相机
少控科技1 天前
小数典 - V1.0.0.1
windows·c#
格林威1 天前
面阵相机 vs 线阵相机:堡盟与海康相机选型差异全解析 附C# 实战演示
开发语言·人工智能·数码相机·计算机视觉·c#·视觉检测·工业相机
刘~浪地球1 天前
日志平台架构设计
c#·linq
玖笙&1 天前
✨WPF编程进阶【9.1】:WPF资源完全指南(附源码)
c++·c#·wpf·visual studio
hhb_6181 天前
Dylan 语言核心特性与工程实践深度解析
开发语言·c#
CSharp精选营1 天前
最新.NET新手入门学习网站合集(2026更新版)
c#·学习资料·开发教程·.net 新手入门·开放资源·.net网站