c# - 将两个查询的左外连接转换为 LINQ

标签 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
            (
                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);

我面临的问题是运行 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;

关于c# - 将两个查询的左外连接转换为 LINQ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32437036/

相关文章:

c# - 从联系人全名中删除头衔

.net - LINQ 到数据表

c# - 更新多行就像批量插入一样

c# - OpenTSDB - 通过 http 获取所有指标

c# - TcpListener - 无法建立连接,因为目标机器主动拒绝它

.net - 列表框在自动回发时滚动到顶部

C# LINQ 存储过程

c# - FluentMongo LINQ : How to query a sublist of a class

.net - LINQ(语言集成查询)的优缺点

c# - 基于类型信息的动态转换