Entity Navigation Property IQueryable cannot be translated into a store expression

前端 未结 2 1755
醉酒成梦
醉酒成梦 2021-01-28 08:40

im using Entity Framework designer first and I need to create custom Model Objects starting from the db objects. I don\'t want to use IEnumerable cause it will query too many fi

相关标签:
2条回答
  • 2021-01-28 09:15

    The problem is that LINQ to Entities is trying to translate your ToModel() method into a SQL query (since that's what LINQ to Entities is supposed to do), and it can't find a way to do it, hence the error that you're seeing.

    In order for you to call ToModel() you'll need to have the information already come in from the database, which will then make any LINQ query a LINQ to Objects query, which will be more than able to do what you are asking for. You can do this by calling ToList() before calling ToModel().

    0 讨论(0)
  • 2021-01-28 09:24

    I think that I need to use something like this: [snip] but I really can't figure out how to use it.

    That's exactly what you need, but you also need LINQKit to make the query work. With it, your code would look like this:

    var toModel = ToModel();
    
    var departments2 = db.departments
        .AsExpandable()
        .Include(p => p.employee)
        .Where(p => true)
        .Select(p => new CustomDepartmentModel()
    {
        ID = p.ID,
        Employees = toModel.Invoke(p.employee).ToList()
    });
    
    0 讨论(0)
提交回复
热议问题