AddDbContext создает 2 экземпляра в 1 запросе - PullRequest
0 голосов
/ 22 октября 2018

У меня есть приложение ASP.NET core 2.1 с ядром EF 2. Я использую встроенный DI. Я регистрирую свои классы следующим образом: в Startup.cs, в ConfigureServices

    var connectionString = this.configuration.GetConnectionString("MYConnection");
     services.AddDbContext<IMyContext, MyContext>(
            options => options.UseSqlServer(connectionString));

     services.AddScoped<IMy1Dao, My1Dao>();
     services.AddScoped<IMy2Dao, My2Dao>();
     services.AddScoped<IMyService, MyService>();

Я внедряюклассы, подобные этому:

public class MyController : Controller, IMyController{      
    private readonly IMyService myService;
    public  MyController(IMyService myService)
    {     
                this.myService = myService;      
    }
    public async Task<List<MyBatchUIDTO>> GetMyBatches([FromBody]List<short> ids)
    {
       return await myService.GetMyBatches(ids);
    }
}
public class MyService : IMyService{
    private readonly IMy1Dao my1Dao;
    private readonly IMy2Dao my2Dao;
    public MyService(IMy1Dao my1Dao, IMy2Dao my2Dao)
    {  
        this.my1Dao = my1Dao;
        this.my2Dao = my2Dao;
    }
}
public  partial class MyContext : DbContext, IMyContext
{   
    public MyContext() { }  
    public MyContext(DbContextOptions<MyContext> options)
    {

}
    //left out DBSET<> details
}
public class My1Dao : IMy1Dao
{
    private IMyContext context
    public My1Dao(IMyContext context)
    {
        this.context = context
    }              
}
public class My2Dao :  IMy2Dao
{
    private IMyContext context
    public My2Dao(IMyContext context)
    {
        this.context = context
    }              
}

Но я получаю 2 разных экземпляра MyContext в конструкторе MyService.Я знаю это, потому что у меня есть точка останова на MyContext Constructora, и она ломается там дважды.Также, когда я читаю из двух DAO, они не делятся возвращенными наборами.Именно это мне и нужно.

...