Ошибки LINQ Join - PullRequest
       2

Ошибки LINQ Join

2 голосов
/ 02 ноября 2010

Я получаю следующую ошибку:

The type of one of the expressions in the join clause is incorrect.  Type inference failed in the call to 'Join'.

при использовании кода ниже

var ccrCodes = (from c in db.CCRCodes
               join i in items on
                new { c.baan_cat_fam_code, c.baan_cat_code } equals
                new { i.baan_cat_family_code, i.baan_cat_code }
               where i => i.contact_dt.Value.Year == date.Year && i.contact_dt.Value.Month == date.Month
               select c).Distinct().OrderBy(c => c.code_desc);

В LINQ я пытаюсь создать соединение с несколькими условиями, и у меня возникают проблемы. Есть идеи?

Спасибо

1 Ответ

3 голосов
/ 02 ноября 2010

Попробуйте дать имена свойствам в ваших анонимных объектах:

var ccrCodes = (from c in db.CCRCodes
               join i in items on
                new { FamCode = c.baan_cat_fam_code, CatCode = c.baan_cat_code } equals
                new { FamCode = i.baan_cat_family_code, CatCode = i.baan_cat_code }
               where i => i.contact_dt.Value.Year == date.Year && i.contact_dt.Value.Month == date.Month
               select c).Distinct().OrderBy(c => c.code_desc);

РЕДАКТИРОВАТЬ: Хорошо, я должен признаться, я не эксперт по синтаксису запроса, но вы хотите отфильтровать список «элементов»перед выполнением объединения, как в следующей беглой версии вашего запроса:

db.CCRCodes
    .Join(
        items.Where(i => i.contact_dt.Value.Year == date.Year && i.contact_dt.Value.Month == date.Month),
        x => new { FamCode = x.baan_cat_fam_code, CatCode = x.baan_cat_code },
        x => new { FamCode = x.baan_cat_family_code, CatCode = x.baan_cat_code },
        (o,i) => o
    ).Distinct().OrderBy(c => c.code_desc)

ДРУГОЕ РЕДАКТИРОВАНИЕ: предложение Per Ahmad:

var ccrCodes = (from c in db.CCRCodes
                   join i in items.Where(x => x.contact_dt.Value.Year == date.Year && x.contact_dt.Value.Month == date.Month) on
                    new { FamCode = c.baan_cat_fam_code, CatCode = c.baan_cat_code } equals
                    new { FamCode = i.baan_cat_family_code, CatCode = i.baan_cat_code }
                   select c).Distinct().OrderBy(c => c.code_desc);

YET ANOTHER EDIT: другое предложение Ahmad:

var ccrCodes = (from c in db.CCRCodes
                from i in items
                where i.contact_dt.Value.Year == date.Year && i.contact_dt.Value.Month == date.Month 
                  && c.baan_cat_fam_code == i.baan_cat_family_code && c.baan_cat_code == i.baan_cat_code
                select c).Distinct().OrderBy(c => c.code_desc); 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...