微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – Queryable.Intersect()与SQLite和Linq没有给出预期的结果

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

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

解决方法:

您是closing over the word变量,并遇到access to modified closure问题.

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

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

foreach (string w in words)
{
    string word = w;
    ...

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐