ToB企服应用市场:ToB评测及商务社交产业平台

标题: Ef Core花里胡哨系列(4) 多租户 [打印本页]

作者: 写过一篇    时间: 2024-3-17 01:13
标题: Ef Core花里胡哨系列(4) 多租户
Ef Core花里胡哨系列(4) 多租户

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

在我的上一篇博客中 [Ef Core花里胡哨系列(3) 动态修改实体对应的表(分表)、多租户] 中我们实现了如何分表,同理,我们可以用近似的方法来切换表的Schema,只需要一点很小的改动。
  1. public class SampleDbContext(DbContextOptions<SampleDbContext> options)
  2.     : DbContext(options)
  3. {
  4.     protected override void OnModelCreating(ModelBuilder modelBuilder)
  5.     {
  6.         modelBuilder.Entity<User>().ToTable($"User{DateTime.Now.ToString("yyyyMM")}", YourSchema);
  7.         base.OnModelCreating(modelBuilder);
  8.     }
  9. }
复制代码
基于多库实现多租户

实现切换数据库我们将会采用的是Interceptor拦截器来实现。
建议租户相关的操作采用单独的DbContext和系统表区分开。
  1. public class TenantDbConnectionInterceptor<T> : DbConnectionInterceptor
  2. {
  3.     public TenantDbConnectionInterceptor()
  4.     {
  5.     }
  6.     public override InterceptionResult ConnectionOpening(DbConnection connection, ConnectionEventData eventData, InterceptionResult result)
  7.     {
  8.         connection.ConnectionString = "对应租户的连接字符串";
  9.         return base.ConnectionOpening(connection, eventData, result);
  10.     }
  11.     public override ValueTask<InterceptionResult> ConnectionOpeningAsync(DbConnection connection, ConnectionEventData eventData, InterceptionResult result, CancellationToken cancellationToken = default)
  12.     {
  13.         connection.ConnectionString = "对应租户的连接字符串";
  14.         return base.ConnectionOpeningAsync(connection, eventData, result, cancellationToken);
  15.     }
  16. }
复制代码
使用拦截器
  1. services.AddDbContext<DynamicDbContext>(opts =>
  2. {
  3.     opts.AddInterceptors(new TenantDbConnectionInterceptor());
  4. });
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4