[英]Cannot apply operator '==' to type 'System,.Nullabe<decimal>' and 'System.Nullable<double>' Error
我试图了解为什么下面的以下方法会引发此错误。 如果有人能帮助或指出我正确的方向,我将不胜感激。
public List<Data> GetResults(string manufacturer, int? vehicle, double? engine )
{
var results =c ontext.Data.Where(x => x.Name == manufacturer)
.Where(x => x.ModelId == model)
.Where(x => x.EngineLitreCapacity == engine) // << error occurs on this line!
.GroupBy(x => x.EngineLitreCapacity)
.Select(x => x.FirstOrDefault())
.ToList();
}
我做错了什么,我将如何解决上述查询? 谢谢
EngineLitreCapacity
似乎是一个decimal?
而你的engine
是double?
. 如果没有强制转换,这些变量是不可比较的。
简单的解决方案是使engine
成为decimal?
. 这可能会导致稍后的投射问题,您必须解决这些问题。 只施放double?
绝对是个坏主意double?
因为它的精度可能会导致方程失败。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.