14

LINQで外部適用を実現するにはどうすればよいですか?少し問題があります。

これが私が使用しているSQLクエリです。

SELECT u.masterID
      ,u.user
      ,h.created
FROM dbo.Users u
OUTER APPLY (SELECT TOP 1 * FROM UserHistory h where h.masterID = u.masterID ORDER BY created DESC) h
4

3 に答える 3

21
from u in Users 
join UserHistory on u.masterID equals h.masterID into h 
select new {
  u.masterID,
  u.user,
  Created = h.Select(x => x.created).OrderByDescending(c => c).FirstOrDefault()
}

または、関連付けを使用して:

from u in Users
let created = u.UserHistories.Select(x => x.created).OrderByDescending(c => c).FirstOrDefault()
select new
{
  u.masterID,
  u.user,
  Created = created
}
于 2010-06-10T12:49:51.820 に答える
7
from u in Users
join UserHistory on u.masterID equals h.masterID into h
select new {u.masterID, u.user, h.created.OrderByDescending().First()}
于 2010-06-10T12:44:17.143 に答える
-1

外部適用は、左外部結合の結果を生成
します。クエリは次のようになります。

var q =
from u in db.Users
join h in db.UserHistory on u.masterID equals h.masterID into ps
from p in ps.DefaultIfEmpty()
select new { 
    masterID = u.masterID
    ,user = u.user
    ,created = ps.OrderByDescending(x=>x.created).FirstOrDefault()==null?null:ps.OrderByDescending(x=>x.created).First().created
};
于 2018-04-26T09:50:48.013 に答える