LINQ连接多个表-没有结果

本文关键字:结果 连接 LINQ | 更新日期: 2023-09-27 18:11:59

我试图使用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连接多个表-没有结果

在LINQ查询中,您通过c.CONTACT_ID过滤,但在SQL查询中,您通过c.CONTACT_TYPE_ID过滤,因此这只是简单的打字错误。