实体框架核心不适用于select(x => MyClass(x))

时间:2016-09-13 10:38:09

标签: entity-framework-core

下面的Get(string _date)方法不起作用。我得到以下异常。我知道EFCore非常有限,但是这个例外无助于查看问题的确切位置。你能解释一下导致这个例外的原因吗?

An unhandled exception occurred while processing the request.

ArgumentException: The given expression 'new EntryViewModel([x])' does not contain the searched expression '[x]' in a nested NewExpression with member assignments or a MemberBindingExpression.
Parameter name: fullExpression
InvokeMethod

TargetInvocationException: Exception has been thrown by the target of an invocation.
InvokeMethod

EntryController.cs

    [HttpGet("{_date}")]
    public async Task<IEnumerable<EntryViewModel>> Get(string _date)
    {
        DateTime date = DateTime.ParseExact(_date, "dd-MM-yyyy", CultureInfo.InvariantCulture);

        User user = await _userManager.GetUserAsync(HttpContext.User);

        var Entries = _context.Entries.Include(x => x.Budget)
            .Where(x => x.User.Id == user.Id && x.Date >= date && x.Date < date.AddDays(7))
            .Select(x=> new EntryViewModel(x))
            .ToList();

        return Entries;     
    }

EntryViewModel.cs

public class EntryViewModel
{
    public int Id { get; set; }
    public int BudgetId { get; set; }
    public string Date { get; set; }
    public int Duration { get; set; }
    public string UserId { get; set; }

    public EntryViewModel(Entry entry)
    {
        Id = entry.Id;
        BudgetId = entry.BudgetId;
        Date = entry.Date.ToString("dd-MM-yyyy", CultureInfo.InvariantCulture);
        Duration = entry.Duration;
        UserId = entry.UserId;
    }
}

3 个答案:

答案 0 :(得分:3)

这个神秘的异常消息说的是,在EF中,如果你想使用x构建一个新对象,它必须采用new C { A = x.B, ... }的形式(其中C可能被省略以投射到匿名类型)。 EF不支持调用任意函数(包括构造函数),只支持一些特定的功能,如调用属性setter。

答案 1 :(得分:1)

您可以尝试如下所示,然后告诉我们结果。

var Entries = _context.Entries.Include(x => x.Budget)
                .Where(x => x.User.Id == user.Id && x.Date >= date && x.Date < date.AddDays(7))
                .Select(e=> new EntryViewModel
                  {
                     BudgetId=e.BudgetId,
                     Duration=e.Duration,
                   }).ToList();

答案 2 :(得分:1)

如果您没有写

,请尝试将AsNoTracking()添加到您的查询中