使用 Entity Framework Core 2 将原始 SQL 映射存储过程结果到 POCO/DTO

sks*_*laj 7 stored-procedures asp.net-core ef-core-2.0

我几乎到处寻找,但我很难找到解决方案。我花了一周时间使用存储过程创建了一个非常复杂的计算查询,我想从这个查询中获取结果并将其放入 POCO 类中,类似于我在使用 EF 6 之前所做的。

将存储过程列名映射到 POCO DTO

基本上是这样的:

var p1 = new SqlParameter { ParameterName = "Param1", Value = 1 };
var p2 = new SqlParameter { ParameterName = "Param2", Value = 2 };
string query = "EXEC Calcs_Selections @Param1, @Param2";
var calcs = context.Database.SqlQuery<CalcViewPOCO>(query, p1, p2).ToList();
Run Code Online (Sandbox Code Playgroud)

我读过这里的文献:

EF Core 查询原始 SQL

没有 DbSet 的原始 SQL 查询 - Entity Framework Core

并发现 EF Core 中不再有“免费 sql”了。FromSQL 基本上将结果投影到在数据库中找到的真实实体中,我不想要它,因为我没有找到具有相同列的表。相反,一种解决方案是扩展 DBContext,并创建一个新的 DBSet

但我真的不知道如何做到这一点。我有一个数据库优先模型,并使用了 Scaffold-DbContext:

使用现有数据库在 ASP.NET Core 上使用 EF Core

我不想添加到自动创建的上下文中,在我的情况下是 ProjectAContext,因为如果我对数据库进行更多更改,并再次运行脚手架,它将覆盖我的更改。

sks*_*laj 4

尽管我迫不及待地希望 EF Core 的新版本能够为我所要求的功能添加功能,但我找到了一个可以帮助我解决此解决方案的库。

https://github.com/snickler/EFCore-FluentStoredProcedure

它允许我获取结果集并映射到 DTO 列表。

存储库中显示的示例:

 var dbContext = GetDbContext();
  dbContext.LoadStoredProc("dbo.SomeSproc")
           .WithSqlParam("fooId", 1)              
           .ExecuteStoredProc((handler) =>
            {                  
                var fooResults = handler.ReadToList<FooDto>();      
                // do something with your results.
            });
Run Code Online (Sandbox Code Playgroud)