[英]Get property from class object in C#
我需要从存储过程中填充的一个类中获取三个属性的值,但不知道如何。
我的viewModel:
public class SitesVM
{
public int ID { get; set; }
public string SiteName { get; set; }
}
我在Global.asax文件中填充一个类,如下所示:
string siteIpAddress = "67.46.255.255"; //HardCoded for testing
var site = context.Database.SqlQuery<SitesVM>("spSelect_SiteByIp", siteIpAddress);
该站点填充了正确的数据,我可以从Locals调试屏幕中看到它,但是我不知道如何将ID和SiteName检索到变量中。 我尝试了以下
var siteID = site.ID; //
但是我得到这个构建错误:
'System.Collections.Generic.IEnumerable'不包含'ID'的定义,并且找不到扩展方法'ID'接受类型为'System.Collections.Generic.IEnumerable'的第一个参数(您是否缺少using指令?或装配参考?)
它返回IEnumerable<SitesVM>
而不是SitesVM
如果您只想要一个结果并且确定只有一个结果,则可以尝试:
site.Single().ID;
这将返回序列中单个成员的ID,如果结果为零或> 1,则将引发异常。
SqlQuery()
函数不返回SitesVM
对象,而是返回此类对象的枚举( IEnumerable
)。 查询结果中可能有零行或更多行。
使用First()
方法获取返回的第一行。 请注意,如果查询不返回任何行(枚举为空),这将引发InvalidOperationException
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.