2

祝大家有美好的一天。

我有实体或复杂类型无法遇到这是我第一次遇到这种类型的错误有人帮助我

    public IEnumerable<APPLICANT> GetApplicant()
    { 
        IEnumerable<APPLICANT> applicantdata = Cache.Get("applicants") as IEnumerable<APPLICANT>;

        IEnumerable<Profile> profiledata = Cache.Get("profiles") as IEnumerable<Profile>;




        if (applicantdata == null)
        {

            var applicantList = (from a in context.Profiles
                                 join app in context.APPLICANTs 
                                 on a.PROFILE_ID equals app.Profile_id
                                where app.APPLICANT_LogicalDelete == false
                                select new APPLICANT()
                                 {
               APPLICANT_LastName = a.Applicant_LASTNAME,
               APPLICANT_FirstName = a.Applicant_FIRSTNAME,
               APPLICANT_MiddleName = a.Applicant_MIDDLENAME,
               APPLICANT_Address = a.Applicant_ADDRESS,
               APPLICANT_City = a.Applicant_CITY,
               APPLICANT_Phone = a.Applicant_PHONE,
                APPLICANT_Email= a.Applicant_EMAIL
           });

            applicantdata = applicantList.Where(v => !String.IsNullOrEmpty(v.APPLICANT_LastName)).OrderBy(v => v.APPLICANT_ID).ToList();

            if (applicantdata.Any())    
            {
                Cache.Set("applicants", applicantdata, 30);
            }
        }
        return applicantdata.ToList().Take(1000);

    }

这是我遇到错误的行谢谢!

applicantdata = applicantList.Where(v => !String.IsNullOrEmpty(v.APPLICANT_LastName)).OrderBy(v => v.APPLICANT_ID).ToList();

上面一行的错误是

System.NotSupportedException:无法在 LINQ to Entities 查询中构造实体或复杂类型“Model.APPLICANT”。

4

2 回答 2

2
select new APPLICANT()

实体框架不支持这一点。它在使用查询时得到诊断,而不是在构造查询时得到诊断,这就是为什么您获得异常的行令人困惑的原因。

你可以构造任何不是数据库实体的类型,包括匿名类型,所以你可以这样做

select new
{
    a.Applicant_LASTNAME,
    a.Applicant_FIRSTNAME,
    a.Applicant_MIDDLENAME,
    a.Applicant_ADDRESS,
    a.Applicant_CITY,
    a.Applicant_PHONE,
    a.Applicant_EMAIL
}

APPLICANT如果需要,您可以在查询完成执行后将这些值放回对象中。

或者,如果合适,您可以APPLICANT直接:

select app

我不确定为什么你在andApplicant_LASTNAME中都有 etc. ,我不知道值是否相同。如果他们不是,那么最后一个建议对您没有用处。ProfileAPPLICANT

于 2013-05-10T08:12:05.163 回答
0

如果我没记错的话,您需要转换为 Queryable 对象。

applicantdata = applicantList.AsQueryable().Where(v => !String.IsNullOrEmpty(v.APPLICANT_LastName)).OrderBy(v => v.APPLICANT_ID).ToList();
于 2013-05-10T08:02:57.300 回答