Помогите с LINQ присоединиться - PullRequest
3 голосов
/ 23 марта 2011
var q = (from Labels in dc.tblArtworkDataLabels select Labels).ToList();

Но мне нужно это, чтобы сделать эквивалент:

SELECT     d.ID, d.labelID, d.dataID, d.data, l.templateID
FROM         tblArtworkDataLabels AS d INNER JOIN
                      tblArtworkData AS l ON d.dataID = l.ID
WHERE     (l.templateID = 238)

Как мне это сделать в LINQ?

Редактировать

Извини! Пропущено предложение WHERE в исходном статменете!

Ответы [ 3 ]

3 голосов
/ 23 марта 2011
var result = dc.tblArtworkDataLabels
    .Join(dc.tblArtworkData, l => l.ID, d => d.dataID, (l, d) => new {l, d})
    .Select(o => new {
         Id = o.d.ID,
         LabelId = o.d.labelID,
         DataId = o.d.dataID, 
         Data = o.d.data, 
         TemplateId = o.l.templateID,
     })
    .Where(o => o.l.templateID == 238);
2 голосов
/ 23 марта 2011

Если у вас есть правильный внешний ключ на tblArtworkData для первичного ключа на tblArtworkDataLabels и вы правильно импортировали их в конструктор DBML, вы можете иметь LINQ2SQL, неявно создающий объединение:

from l in tblArtworkData
where l.templateID = 238
select new {
    Id = l.tblArtworkDataLabel.ID,
    LabelId = l.tblArtworkDataLabel.labelID,
    DataId = l.tblArtworkDataLabel.dataID,
    Data = l.tblArtworkDataLabel.data,
    TemplateId = l.templateID,
}

См. мой ответ на вопрос "LINQ to SQL: множественные объединения в нескольких столбцах. Возможно ли это?"для того, как неявное объединение преобразуется в SQL.

Редактировать:

В случае, если я неправильно понял ваши отношения, и у вас есть много tblArtworkDataLabels к одному tblArtworkData, вы должны повернуть запрос к другомунаоборот

from d in tblArtworkDataLabels
where d.tblArtworkData.templateID = 238
select new {
    Id = d.ID,
    LabelId = d.labelID,
    DataId = d.dataID,
    Data = d.data,
    TemplateId = d.tblArtworkData.templateID,
}
1 голос
/ 23 марта 2011

1001 * попробовать *

var q = (from Labels in dc.tblArtworkDataLabels
         join data in dc.tblArtworkData on Labels.ID equals data.DataID select Labels).ToList();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...