0

私のlinqは、すべてのセットに対して繰り返されるすべての同じ行を返します

DB で SQL を実行します。

select top 20 * from t1
left join t2
on t1.sid= t2.sid
 and t1.pid=t2.pid
where(t2.sid is null and t1.pid='r')

20 の異なる行の結果を取得できます。

それから私はLinqを書きます:

    Entities dbconn = new Entities();
    List<t1> myResult = (
        from t1Data in dbconn.t1
        join t2Data in dbconn.t2
        on new     { sid = (int)t1.sid,    pid= t1.pid}
        equals new { sid= (int)t2.sid, pid= t2.pid}
        into joinSet
        from joinUnit in joinSet.DefaultIfEmpty()
        where (joinUnit == null) && (t1.pid== "r")
        select t1Data 
        ).Take(20).ToList();

結果のすべての行はいくつかの行です。

4

1 に答える 1