c# – 我如何优化这个lambda表达式,使用包含单词列表的每一行的
发布时间:2020-12-16 00:07:41 所属栏目:百科 来源:网络整理
导读:我有一些意见,如:“Steve Brian McFistycuffs Johnson” 我想查看我的数据库,并以任何顺序返回包含这些单词的所有记录. 我做的是什么 var matches = myContext.MyTable.Where(c = c.Name.Contains(“Steve”) c.Name.Contains(“Brian”) c.Name.Contains(
我有一些意见,如:“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语句,例如.我想确保尽可能优化它. 有什么建议? 解决方法
就像是:
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); } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |