奇怪的linq2sql /让错误?

时间:2009-03-10 12:16:54

标签: linq-to-sql

有人可以解释为什么存在以下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)

工作正常??

1 个答案:

答案 0 :(得分:1)

由于我们无法复制它,你能定义“打破应用程序”吗?你能引用错误信息吗?有关信息,我偶尔会看到表达式编译器做出关于可空性的可疑决定 - 更多信息请参阅here。这可能是相关的,但没有错误信息就无法说出来。