4

我想通过几个关键字搜索书籍数据库。我提供的关键字越多,搜索范围就越窄。这是我的代码:

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() 调用将无法可靠地工作。我的想法是有缺陷的,还是我实现它的方式有缺陷?

4

1 回答 1

5

您正在关闭word变量,并遇到访问修改后的关闭问题。

在循环的每次迭代中,您都将words集合中的字符串值捕获到变量word中。但是 LINQ 使用延迟执行,并且您的查询直到循环完成后才会执行,此时您的查询的所有实例都会捕获相同的单词变量 - 因此您会看到结果随提供的搜索关键字的顺序而变化.

要解决此问题,请在循环的每次迭代中获取变量的本地副本。

foreach (string w in words)
{
    string word = w;
    ...
于 2011-03-21T08:26:14.930 回答