簡體   English   中英

將當前事務傳遞給DbCommand

[英]Pass current transaction to DbCommand

我正在使用ASP.NET Core 2.1和EF Core 2.1開發一個項目。 雖然大多數查詢和命令都使用EF,但某些單元需要直接調用存儲過程。

我不能使用FromSql ,因為它需要基於實體模型的結果集。

我們假設我們有這些方法:

public Task CommandOne(DbContext context)
{
    Entity entity = new Entity
    {
        Name = "Name"
    };
    context.DbSet<Entity>().Add(entity);
    return context.SaveChangesAsync();
}

public async Task CommandTwo(DbContext context)
{
    DbCommand command = context.Database.GetDbConnection().CreateCommand();
    command.CommandText = "storedProcName";
    command.CommandType = System.Data.CommandType.StoredProcedure;

    using (var reader = await command.ExecuteReaderAsync().ConfigureAwait(false))
    {
        // read result sets
    }
}

如果我在一個事務中調用這兩個命令,如下所示:

public async Task UnitOfWork(DbContext dbContext)
{
    using (var transaction = await dbContext.Database.BeginTransactionAsync())
    {
        await CommandOne(dbContext);
        await CommandTwo(dbContext);
    }
}

這個例外將會發生:

當分配給命令的連接處於掛起的本地事務中時,BeginExecuteReader要求該命令具有事務。 該命令的Transaction屬性尚未初始化。

我不得不提一下,它不像command.Transaction = ...那么簡單。 這需要DbTransaction ,它與EF使用的事務不同。

我已經放了一個月了! 這有什么解決方法嗎? 非常感謝。

我不得不提一下,它不像command.Transaction = ....這需要DbTransaction ,它與EF使用的事務不同。

實際上是。 您只需要參考Microsoft.EntityFrameworkCore.Relational程序集並添加

using Microsoft.EntityFrameworkCore.Storage;

訪問GetDbTransaction擴展方法:

if (context.Database.CurrentTransaction != null)
    command.Transaction = context.Database.CurrentTransaction.GetDbTransaction();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM