0

我正在为移动应用程序创建 web api,我需要在用户注册时将数据添加到数据库,我想将数据添加到多个表

我的用户表设计:

  • AspnetUsers:默认身份表
  • StudentUsers:第二张用户明细表
  • TeacherUsers:用户的第三张表

注册时,用户选择他们是学生还是老师。这里的问题是,注册时有两个表,我想针对这种情况使用工作单元,以防止数据保存失败。如果数据失败不要将数据添加到其他表中。

但是我怎样才能将它实现到身份中呢?

4

1 回答 1

0

您不需要过度思考/过度使用 Entity Framework Core 的工作单元。

看:

https://gunnarpeipman.com/ef-core-repository-unit-of-work/

所以要得到你的“交易”,你会打电话

myInjectedContext.BeginTransaction().
/* alter any/all of the 3 DbSets */
    myInjectedContext.Commit();

其中 myInjectedContext 是 IDataContext。

public class MyTransactionallyFriendlyDbContext : DbContext /*(, IDataContext) */
{
    public LasteDbContext(DbContextOptions<LasteDbContext> options)
        : base(options)
    {
    }
 
    public DbSet<AspnetUser> AspnetUsers { get; set; }
    public DbSet<StudentUser> StudentUsers { get; set; }
    public DbSet<TeacherUser> TeacherUsers { get; set; }
    
    private IDbContextTransaction _transaction;
 
    public void BeginTransaction()
    { 
        _transaction = Database.BeginTransaction();
    }
 
    public void Commit()
    {
        try
        {
            SaveChanges();
            _transaction.Commit();
        }
        finally
        {
            _transaction.Dispose();
        }        
    }
 
    public void Rollback()
    { 
        _transaction.Rollback();
        _transaction.Dispose();
    }
}

这是一个满足 Ioc/单元测试需求的接口。

public interface IDataContext
{
    DbSet<AspnetUser> AspnetUsers { get; set; }
    DbSet<StudentUser> StudentUsers { get; set; }
    DbSet<TeacherUser> TeacherUsers { get; set; }
 
    void BeginTransaction();
    void Commit();
    void Rollback();
}
于 2020-08-12T19:17:03.790 回答