C# 将两个查询上的左外部联接转换为LINQ

C# 将两个查询上的左外部联接转换为LINQ,c#,.net,linq,sql-server-2008,linq-to-sql,C#,.net,Linq,Sql Server 2008,Linq To Sql,我有下面的sql查询,我想将其转换为LINQ以获得完全相同的结果,并通过下面的查询返回 select * from ( select distinct DocID from UserViewDoc where UserViewDoc.UVID in (102558)) a left outer join (

我有下面的sql查询,我想将其转换为LINQ以获得完全相同的结果,并通过下面的查询返回

    select *
             from (
                select distinct DocID 
                from UserViewDoc 
                where UserViewDoc.UVID in (102558)) a 
         left outer join
            (
                select distinct UserViewDoc.DocID 
                from UserViewDoc 
                     inner join UserViewHeader on UserViewDoc.UVID =        UserViewHeader.UVID 
                where UserViewDoc.UVID not in (102558) 
                  and UserViewHeader.IsLock = 1) b on a.DocID = b.DocID
         where b.DocID is  null
         )
到目前为止,我所尝试的是下面的LINQ声明

   var v = (from uvd in this.ViewSelectorControl.LDReviewContext.GetTable<UserViewDoc>()
                 where IDs.Contains(uvd.UVID)
                 select new { uvd.DocID, uvd.UVID });
        var c = ((from uvd in this.ViewSelectorControl.LDReviewContext.GetTable<UserViewDoc>()
                 join uvh in this.ViewSelectorControl.LDReviewContext.GetTable<UserViewHeader>() on uvd.UVID equals uvh.UVID
                 where !IDs.Contains(uvh.UVID) && uvh.IsLock == true
                 select new { uvd.DocID, uvd.UVID } ));
        var d = (from id in v
                 join ids in c on id.UVID equals ids.UVID into vc
                 from sub in vc.DefaultIfEmpty()
                 where sub == null
                 select id);
var v=(来自此.ViewSelectorControl.LDReviewContext.GetTable()中的uvd)
其中id.Contains(uvd.UVID)
选择新建{uvd.DocID,uvd.UVID});
var c=((来自this.ViewSelectorControl.LDReviewContext.GetTable()中的uvd)
在uvd.UVID上的.ViewSelectorControl.LDReviewContext.GetTable()中加入uvh。UVID等于uvh.UVID
其中!IDs.Contains(uvh.UVID)&&uvh.IsLock==true
选择新的{uvd.DocID,uvd.UVID});
变量d=(从v中的id开始)
将id.UVID等于id.UVID的c中的id连接到vc中
从vc.DefaultIfEmpty()中的子对象
其中sub==null
选择id);

我面临的问题是运行SQL查询时返回30583条记录,而它的LINQ版本返回所有30613条记录

我重新编写了与SQL查询完全相同的查询,我相信这是一种方式:

var firstQuery = (from u in this.ViewSelectorControl.LDReviewContext.GetTable<UserViewDoc>()
                  where IDs.Contains(u.UVID)
                  select u.DocID).Distinct();

var innerQuery = (from u in this.ViewSelectorControl.LDReviewContext.GetTable<UserViewDoc>()
                      join uvh in this.ViewSelectorControl.LDReviewContext.GetTable<UserViewHeader>() on uvh.UVID equals u.UVID
                      where IDs.Contains(u.UIVD) == false
                      && uvh.IsLock
                      select u.DocID).Distinct();

var resultQuery = from f in firstQuery
                  join i in innerQuery on i equals f into lout
                  from i in lout.DefaultIfEmpty()
                  where i == null
                  select f;
var firstQuery=(此.ViewSelectorControl.LDReviewContext.GetTable()中的u)
其中id.Contains(u.UVID)
选择u.DocID).Distinct();
var innerQuery=(此.ViewSelectorControl.LDReviewContext.GetTable()中的u)
在uvh.UVID等于u.UVID上的.ViewSelectorControl.LDReviewContext.GetTable()中加入uvh
其中id.Contains(u.UIVD)=false
&&伊斯洛克
选择u.DocID).Distinct();
var resultQuery=来自firstQuery中的f
将i等于f的innerQuery中的i连接到lout中
来自lout.DefaultIfEmpty()中的i
其中i==null
选择f;

展示自己的努力很好,但是你能告诉我为什么它显然没有达到你想要达到的目标吗?此外,通常可以使用导航属性而不是LINQ连接来解决连接问题。@GertArnold谢谢!!,很抱歉,我错过了这一条,实际上,当我运行sql查询时,它返回30583条记录,但在LINQ中运行相同的东西会返回所有30613条记录。另外,我可以使用导航属性,因为这最终会将一百万条记录加载到memeory中。您的SQL和LINQ语句不会做同样的事情。这可能解释了返回行中的差异。您的实际SQL是什么?您能否提供一些SQL代码,这些代码将创建表,并允许在表中插入一些初始值,以便了解您的代码的作用?@Yurazaletsky我无法给出实际的表,但是,假设这两个表都包含UVID和DocID,并且表UserViewHeader包含更多字段IsLock。现在,我想要的是UserViewDoc中的所有记录,除了那些特定UVID中IsLock为true的记录