c# – 我如何优化这个lambda表达式,使用包含单词列表的每一行的实体框架进行查询?

我有一些意见,如:“Steve Brian McFistycuffs Johnson”

我想查看我的数据库,并以任何顺序返回包含这些单词的所有记录.

我做的是什么

var matches = myContext.MyTable.Where(c => c.Name.Contains(“Steve”)&& c.Name.Contains(“Brian”)&& c.Name.Contains(“McFistycuffs” )&& c.Name.Conains(“Johnson”));

但是我需要动态地执行此操作,并且单词的数量可能会发生变化.

我还想确保无论我选择什么,它都不会影响实体框架创建sql语句,例如.我想确保尽可能优化它.
这意味着在lambda中做某种foreach可能不会起作用,因为实体框架不能轻易地将它映射到sql.

有什么建议?

解决方法

就像是:

static void Main()
{
    string[] words = {"abc","def"};
    var filter = ContainsAllWords<Person>(x => x.Name,words);
    // same as: x => x.Name.Contains("abc") && x.Name.Contains("def")

    // then:
    var rows = myContext.MyTable.Where(filter);
}
static Expression<Func<T,bool>> ContainsAllWords<T>(
    Expression<Func<T,string>> selector,string[] words)
{
    if (words == null || words.Length == 0) return x => true;

    Expression body = Expression.Call(selector.Body,"Contains",null,Expression.Constant(words[0],typeof(string)));
    for (int i = 1; i < words.Length; i++)
    {
        body = Expression.AndAlso(body,Expression.Call(selector.Body,Expression.Constant(words[i],typeof(string))));
    }
    return Expression.Lambda<Func<T,bool>>(body,selector.Parameters);
}

相关文章

目录简介使用JS互操作使用ClipLazor库创建项目使用方法简单测...
目录简介快速入门安装 NuGet 包实体类User数据库类DbFactory...
本文实现一个简单的配置类,原理比较简单,适用于一些小型项...
C#中Description特性主要用于枚举和属性,方法比较简单,记录...
[TOC] # 原理简介 本文参考[C#/WPF/WinForm/程序实现软件开机...
目录简介获取 HTML 文档解析 HTML 文档测试补充:使用 CSS 选...