[英]Joining between multiple tables with LINQ is not showing accurate results
[英]LINQ Joining Multiple Tables - No Results
我正在尝试使用LINQ联接多个表,并检索分配方法的名称。 我有一个用作基础的SQL语句,如下。
select dt.NAME
from i_doc.dbo.document as d
join i_doc.dbo.CONTACT as c
on c.DOC_ID = d.DOC_ID
join i_doc.dbo.RECIPIENT as r
on r.CONTACT_ID = c.CONTACT_ID
join i_doc.dbo.DISTRIBUTION_TYPE as dt
on dt.DISTRIBUTION_TYPE_ID = r.DISTRIBUTION_TYPE_ID
where c.CONTACT_TYPE_ID = 2
and r.DISTRIBUTION_TYPE_ID != 6
and d.DOC_ID = 28757
此特定查询返回1个项目。 但是,我拥有的LINQ代码什么也不返回。 LINQ代码如下。
var distributionMethod = (from d in _documentEntities.DOCUMENTs
join c in _documentEntities.CONTACTs on d.DOC_ID equals c.DOC_ID
join r in _documentEntities.RECIPIENTs on c.CONTACT_ID equals r.CONTACT_ID
join dt in _documentEntities.DISTRIBUTION_TYPE on r.DISTRIBUTION_TYPE_ID equals dt.DISTRIBUTION_TYPE_ID
where c.CONTACT_ID == 2
&& r.DISTRIBUTION_TYPE_ID != 6
&& d.DOC_ID == DocID
select dt.NAME).ToList();
在尝试确定发生了什么情况时,我们简化了查询以测试连接是否正确建立,并测试了以下LINQ。
var test = (from dt in _documentEntities.DISTRIBUTION_TYPE
select dt.NAME).Take(100);
LINQ var测试得出适当的值。
我的问题是:为什么我的distributionMethod LINQ查询不返回任何内容,我该怎么做才能解决它?
谢谢
在LINQ查询中,您通过c.CONTACT_ID
过滤,但是在SQL查询中,您通过c.CONTACT_TYPE_ID
过滤,因此这只是简单的错字。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.