我有一个疑问:
int maxShoeSize = Workers
.Where(x => x.CompanyId == 8)
.Max(x => x.ShoeSize);
如果公司8根本没有工人,maxShoeSize中会有什么?
更新: 我如何改变查询,以获得0,而不是一个异常?
我有一个疑问:
int maxShoeSize = Workers
.Where(x => x.CompanyId == 8)
.Max(x => x.ShoeSize);
如果公司8根本没有工人,maxShoeSize中会有什么?
更新: 我如何改变查询,以获得0,而不是一个异常?
当前回答
注意:使用DefaultIfEmpty()的查询可能会显著变慢。 在我的情况下,这是一个简单的查询。defaultifempty (DateTime.Now.Date)。
我懒得分析它,但显然EF试图获得所有行,然后取Max()值。
结论:有时处理InvalidOperationException可能是更好的选择。
其他回答
在这种情况下Max()不会返回任何东西。
它将引发InvalidOperationException异常,因为源不包含任何元素。
int maxShoeSize = Workers.Where(x => x.CompanyId == 8)
.Select(x => x.ShoeSize)
.DefaultIfEmpty()
.Max();
您可以在执行Max()之前检查是否有任何工作人员。
private int FindMaxShoeSize(IList<MyClass> workers) {
var workersInCompany = workers.Where(x => x.CompanyId == 8);
if(!workersInCompany.Any()) { return 0; }
return workersInCompany.Max(x => x.ShoeSize);
}
注意:使用DefaultIfEmpty()的查询可能会显著变慢。 在我的情况下,这是一个简单的查询。defaultifempty (DateTime.Now.Date)。
我懒得分析它,但显然EF试图获得所有行,然后取Max()值。
结论:有时处理InvalidOperationException可能是更好的选择。
你可以试试这个:
int maxShoeSize = Workers.Where(x=>x.CompanyId == 8).Max(x => x.ShoeSize) ?? 0;