joc*_*ull 5 c# entity-framework anonymous-types
在实体框架中,您可以像这样运行和绑定自定义查询...
protected class NitrogenMoisutreContainer
{
public double MinN { get; set; }
public double MaxN { get; set; }
public double MinM { get; set; }
public double MaxM { get; set; }
}
// ...
var q = dbcontext.Database.SqlQuery<NitrogenMoisutreContainer>(@"SELECT MAX(NitrogenBalance) as MaxN, MIN(NitrogenBalance) as MinN, MAX(FCWaterPercent) as MaxM, MIN(FCWaterPercent) as MinM
FROM agZoneProjectionGrowthStages
WHERE NitrogenBalance > 0 AND FCWaterPercent > 0").First();
Run Code Online (Sandbox Code Playgroud)
问题是,对我来说,这感觉很麻烦.我必须为一个查询创建这个类,我永远不会再用它来做任何其他事情.结果使用的位置与执行位置相差一行.
有没有办法可以返回匿名类型?即使我必须先声明它,像这样......
var anonItem = new {
MinN = 0d,
MaxN = 0d,
MinM = 0d,
MaxM = 0d
};
var q = dbcontext.Database.SqlQuery<anonItem.GetType()>("...");
Run Code Online (Sandbox Code Playgroud)
我只是无法弄清楚如何在我的匿名类型的传递Type为T.可能吗?
如果您进行设置,则可以执行此操作,以便可以推断出类型.例如
public static IEnumerable<T> GetObjects<T>(T exampleItem, string sqlQuery) { ... }
var q = GetObjects(anonItem, @"");
Run Code Online (Sandbox Code Playgroud)
我认为这有点hackish,我建议尝试另一种方法,比如实际创建命名类或使用元组.