有人可以解释为什么存在以下linq查询...
(from e in db.Clients
let
log = (from f in db.CreditsafeLogs where f.Vat.Equals(e.VAT) orderby f.Sent descending select f).FirstOrDefault()
where
e.DeleteFlag.Equals("n") &&
e.Active == true &&
log != null &&
log.Approved == false
select e.Id)
编译,但在运行时中断了应用程序(即使它从未调用过),而它是等效的
Clients
.Select (
e =>
new
{
e = e,
log = CreditsafeLogs
.Where (f => f.Vat.Equals (e.VAT))
.OrderByDescending (f => f.Sent)
.FirstOrDefault ()
}
)
.Where (
temp0 =>
(((temp0.e.DeleteFlag.Equals ("n") && (temp0.e.Active == (Boolean?)True)) &&
(temp0.log != null)
) &&
(temp0.log.Approved == False)
)
)
.Select (temp0 => temp0.e.Id)
工作正常??
答案 0 :(得分:1)
由于我们无法复制它,你能定义“打破应用程序”吗?你能引用错误信息吗?有关信息,我偶尔会看到表达式编译器做出关于可空性的可疑决定 - 更多信息请参阅here。这可能是相关的,但没有错误信息就无法说出来。