繁体   English   中英

避免客户端评估,同时在 EF Core 3 中保持干净的代码

[英]Avoid client evaluation while maintain clean code in EF Core 3

我需要向我的数据库编写更复杂的查询。 通过客户端评估很容易维护干净的代码,但我正在处理大量数据并且需要保持我的后端快速。

客户实体就是一个很好的例子。 这就是我的查询现在的样子:

public class CustomerFilter : AbstractProjectFilter
{
    public CustomerFilter(string query, bool includeNotSet, ICollection<string> customers) :
        base(e => (customers == null)
                  || (includeNotSet && e.Customer == null)
                  || (customers.Contains("Company") && e.Customer.Type == CustomerType.Company &&
                      EF.Functions.Like((((CustomerCompany)e.Customer).Name + " " + ((CustomerCompany)e.Customer).Crn + " " + ((CustomerCompany)e.Customer).VatRegNo), "%" + query + "%"))
                  || (customers.Contains("Person") && e.Customer.Type == CustomerType.Person &&
                      EF.Functions.Like(((CustomerPerson)e.Customer).Forename + " " + ((CustomerPerson)e.Customer).Surname, "%" + query + "%"))
                  || (customers.Contains("Evidence") && e.Customer.Type == CustomerType.InEvidence &&
                      EF.Functions.Like(e.Customer.EvidenceName, "%" + query + "%"))
        )
    {
    }
}

启用客户端评估后,这会更加简洁,因为我可以使用这种方法来创建基于客户派生类型的名称字符串,并使用扩展方法(我故意避免使用虚拟方法),并使用它来缩短我的查询和清洁:

public static string NameString(this Customer customer)
    {
        if (customer.IsObjectNull())
            return string.Empty;

        return customer.Type switch
        {
            CustomerType.InEvidence => ((CustomerInEvidence) customer).EvidenceName,
            CustomerType.Person => (((CustomerPerson) customer).Forename + " " +
                                    ((CustomerPerson) customer).Surname),
            CustomerType.Company => ((CustomerCompany) customer).Name,
            _ => throw new ArgumentOutOfRangeException()
        };
    }

我的问题:有没有办法告诉数据库如何处理方法而不需要从中获取数据? 我缺少 Fluent API 的一些配置?

如果我能够在使用 Linq.Dynamic 进行排序时使用这些“方法”,那就太好了,如下所示:

var orderedCustomers = await customers.OrderBy("*string_created_by_some_method* ASC").ToListAsync();

有没有办法告诉数据库如何处理方法而不需要从中获取数据? 我缺少 Fluent API 的一些配置?

没有什么直截了当的方式,这就是Expression的方式!

在不获取数据的情况下与数据库通信的唯一方法是使用Expressions 它不是很直,但可以做你需要的一切。

你可以在这里看到一个例子

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM