sks*_*laj 7 stored-procedures asp.net-core ef-core-2.0
我几乎到处寻找,但我很难找到解决方案。我花了一周时间使用存储过程创建了一个非常复杂的计算查询,我想从这个查询中获取结果并将其放入 POCO 类中,类似于我在使用 EF 6 之前所做的。
基本上是这样的:
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)
我读过这里的文献:
没有 DbSet 的原始 SQL 查询 - Entity Framework Core
并发现 EF Core 中不再有“免费 sql”了。FromSQL 基本上将结果投影到在数据库中找到的真实实体中,我不想要它,因为我没有找到具有相同列的表。相反,一种解决方案是扩展 DBContext,并创建一个新的 DBSet
但我真的不知道如何做到这一点。我有一个数据库优先模型,并使用了 Scaffold-DbContext:
使用现有数据库在 ASP.NET Core 上使用 EF Core
我不想添加到自动创建的上下文中,在我的情况下是 ProjectAContext,因为如果我对数据库进行更多更改,并再次运行脚手架,它将覆盖我的更改。
尽管我迫不及待地希望 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)
归档时间: |
|
查看次数: |
3361 次 |
最近记录: |