簡體   English   中英

LINQ連接多個表-沒有結果

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM