gpt4 book ai didi

c# - 将 EF 原始 SQL 查询映射到特定属性?

转载 作者:太空宇宙 更新时间:2023-11-03 21:15:30 25 4
gpt4 key购买 nike

我有一个相当复杂的 SQL 查询,建议将其作为原始 SQL 运行,而不是转换为 LINQ。查看示例,我必须给它一个对象来制作列表。所以我创建了一个类,它可以更好地表示属性名称而不是表列名称。但是,我似乎无法使用这些属性并且必须使属性名称与数据库的列名称相匹配。

我有一个名为 Region 的类,它具有以下属性

public string RegionName { get; set; }
public string DepartingStation{ get; set; }

但是,数据库列名是

REG_NAME
DEP_STATION

如果我有与数据库列相同的属性名称,它会返回结果。但是,我更愿意为我们提供更好的属性名称。有没有办法可以将类属性名称映射到特定的数据库字段?

using (ApiDbContext db = new ApiDbContext())
{
var results = db.Database.SqlQuery<Region>(sbQuery.ToString()).ToList();
}

最佳答案

在这种情况下,我建议从原始 sql 输出列别名以匹配类属性名称。所以如果你有:

public class Region {
public string RegionName { get; set; }
public string DepartingStation{ get; set; }
}

然后你像这样写原始的sql:

var subquery = @"
select
REG_NAME as RegionName,
DEP_STATION as DepartingStation
from Table1"

有了它,您就可以安全地调用:

var results = db.Database.SqlQuery<Region>(subquery).ToList();

results 将是区域项目的本地通用列表,List<Region>.你可以循环并用它做你需要做的事情。

关于c# - 将 EF 原始 SQL 查询映射到特定属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34641292/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com