여러 데이터베이스로 책 데이터베이스를 검색하고 싶습니다. 더 많은 키워드를 제공할수록 검색 범위가 좁아집니다. 검색이 사실 좁은 I가 제공하는 키워드를하지 않습니다,SQLite 및 Linq이 예상 결과를 제공하지 않는 Queryable.Intersect()
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() 호출이 안정적으로 작동하지 않습니다. 내 아이디어가 결함인가, 구현 방법인가?
저는 System.Data.SQLite.SQLiteConnection과 System.Data.Linq.DataContext를 사용하고 있습니다. –