首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LINQ连接错误

LINQ连接错误
EN

Stack Overflow用户
提问于 2010-11-03 01:59:15
回答 1查看 364关注 0票数 2

我得到以下错误:

代码语言:javascript
复制
The type of one of the expressions in the join clause is incorrect.  Type inference failed in the call to 'Join'.

使用以下代码时

代码语言:javascript
复制
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中做的是创建一个多条件连接,但遇到了问题。有什么想法吗?

谢谢,

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-11-03 02:01:54

尝试为匿名对象中的属性命名:

代码语言:javascript
复制
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);

编辑:好的,我必须承认,我不是查询语法方面的专家,但是你想在连接之前过滤“项目”列表,就像你的查询的流利版本:

代码语言:javascript
复制
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)

另一个编辑:根据艾哈迈德的建议:

代码语言:javascript
复制
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);

又一次编辑:根据另一条Ahmad的建议:

代码语言:javascript
复制
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); 
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4080641

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档