Nib*_*Pig 3 c# lambda entity-framework
我有一些输入,像这样: "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, "Contains", null,
Expression.Constant(words[i], typeof(string))));
}
return Expression.Lambda<Func<T, bool>>(body, selector.Parameters);
}
Run Code Online (Sandbox Code Playgroud)