47

LINQ の次のステートメントに相当するものは何ですか。

Select t1.appname, t1.julianDte, t1.cat 
From table1 t1 
Where NOT EXISTS 
   ( Select * 
     from table t2 
     where t1.cat = t2.cat AND t2.julianDte < t1.julianDte )
4

3 に答える 3

62

このNot Anyパターンを試してください。

var query = db.table1
.Where(t1 => !db.table2
  .Any(t2 => t2.cat == t1.cat && t2.julianDte < t1.julianDte)
);
于 2009-05-22T17:52:32.260 に答える
11

@Amy B の回答のクエリ構文バージョン (!Any を All に反転):

from t1 in db.Table1
where db.Table2.All(t2 => t1.cat != t2.cat || t2.julianDte >= t1.julianDte)
select new
{
    t1.appname,
    t1.julianDte,
    t1.cat
};
于 2009-05-23T05:59:45.700 に答える
1
from t1 in Context.table1DbSet
let ok = 
    (from t2 in Context.table2DbSet 
     where t2.Idt1 = t1.Idt1 && t1.DateValid.HasValue
    ).Any()
where 
   t1.Active
   && !ok
于 2016-06-01T13:48:03.410 に答える