我有下面的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;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。