首页 > 解决方案 > EF Core 2.1 按自有类型过滤

问题描述

我正在开发一个使用 Entity Framework Cor 2.1 和 Aspnet Core Web API 的项目。

我有以下 ValueObject

public class Email
{
    private string _value;

    private Email(string value) => _value = value;

    public static Email Create(string email)
    {
        //... code hidden for clarity
        return new Email(email);
    }

    // I have overridden equality operators to check equality by the _value property
    // and also ToString to return _value
}

我将此值对象配置为 Person 实体中的自有类型。

public class Person
{
    //... code hidden for clarity
    public virtual Email Email {get; private set;}
}

当我用say查询数据库时

_context.People.Where(person => person.Email == Email.Create("example@example.com");

我在控制台上收到以下警告。

 The LINQ expression 'where ([person.Email] == __email_0)' could not be translated and will be evaluated locally.

我的 Person 表中只有几条记录,但是当它有更多记录时会影响性能吗?是否有解决方法。

标签: entity-framework-coredomain-driven-designef-core-2.1owned-types

解决方案


您期望 EF Core 将本地客户端代码(而不是表达式)转换为 SQL 代码,但它不会这样做,这就是它告诉您它将在本地评估的原因。

我建议实现一个值转换器,其中ConvertToProviderExpressionandConvertFromProviderExpression表达式可以处理您在数据库中存储和读取的自定义逻辑。


推荐阅读