我想通过几个关键字搜索图书数据库。我提供的关键字越多,搜索范围就越窄。这是我的代码:
var words = text.Split(' ');
IQueryable<Reference> query = null;
foreach (string word in words)
{
var result = from r in _dbConnection.GetTable<Reference>()
where r.Title.Contains(word)
|| r.ReferenceAuthor.Any(a => a.Person.LastName.Contains(word) || a.Person.FirstName.Contains(word))
|| r.ReferenceCategory.Any(c => c.Category.Name.Contains(word))
|| r.ReferenceKeyword.Any(k => k.Keyword.Name.Contains(word))
orderby r.Title
select r;
query = query == null ? result : query.Intersect(result);
}
query.OrderBy(r => r.Title);
问题是,我提供的关键字越多,搜索实际上就越少。结果甚至取决于我提供关键字的顺序。 此外,如果涉及多个关键字,则最后一次OrderBy()调用无法可靠地工作。我的想法有缺陷,还是我实施它的方式?
答案 0 :(得分:5)
您是closing over the word
变量,遇到access to modified closure问题。
在循环的每次迭代中,您将从words
集合中捕获字符串的值到变量word
。但是LINQ使用延迟执行,并且在循环完成之后查询才会执行,此时查询的所有实例都会捕获相同的单词变量 - 因此您会看到结果因提供的搜索关键字的顺序而异。
要解决此问题,请在循环的每次迭代中获取变量的本地副本。
foreach (string w in words)
{
string word = w;
...