Moh*_*ari 7 c# asp.net-core-mvc ef-core-2.1
我正在使用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
}
}
Run Code Online (Sandbox Code Playgroud)
如果我在一个事务中调用这两个命令,如下所示:
public async Task UnitOfWork(DbContext dbContext)
{
using (var transaction = await dbContext.Database.BeginTransactionAsync())
{
await CommandOne(dbContext);
await CommandTwo(dbContext);
}
}
Run Code Online (Sandbox Code Playgroud)
这个例外将会发生:
当分配给命令的连接处于挂起的本地事务中时,BeginExecuteReader要求该命令具有事务.该命令的Transaction属性尚未初始化.
我不得不提,它不是那么简单command.Transaction = ....这要求DbTransaction与EF使用的事务不同.
我已经放了一个月了!这有什么解决方法吗?非常感谢.
Iva*_*oev 10
我不得不提一下,它并不像它所要求的那样简单,
command.Transaction = ....这DbTransaction与EF使用的事务不同.
实际上是.您只需要参考 Microsoft.EntityFrameworkCore.Relational程序集并添加
using Microsoft.EntityFrameworkCore.Storage;
Run Code Online (Sandbox Code Playgroud)
访问GetDbTransaction扩展方法:
if (context.Database.CurrentTransaction != null)
command.Transaction = context.Database.CurrentTransaction.GetDbTransaction();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
637 次 |
| 最近记录: |