我需要根据搜索生成关键字的自动填充功能列表,其中每个关键字都有一组KeywordSearch:
关键字类:
public class Keyword
{
public int Id { get; set; }
public string Name { get; set; }
}
public class KeywordSearch
{
// Primary properties
public int Id { get; set; }
public string Name { get; set; }
public Keyword Keyword { get; set; }
}
所以,如果有一个像“公司名称”这样的关键字,我将拥有KeywordSearch“公司”和“名称”。
我现在拥有的功能不太好:
public IList<KeywordDto> GetAllBySearch(string keywords, int numberOfRecords)
{
var splitKeywords = keywords.Split(new Char[] { ' ' });
var keywordQuery = _keywordRepository.Query.Where(p => p.IsActive == true);
var keywordSearchQuery = _keywordSearchRepository.Query;
var keywordIds = keywordSearchQuery
.GroupBy(k => k.Keyword.Id)
.Where(g => splitKeywords.All(w => g.Any(k => w.Contains(k.Name))))
.Select(g => g.Key);
IList<KeywordDto> keywordList = (from kw in keywordQuery
join kwids in keywordIds on kw.Id equals kwids
select new KeywordDto { Id = kw.Id, Name = kw.Name })
.Take(numberOfRecords)
.Distinct()
.OrderBy(p => p.Name).ToList();
return keywordList;
}
我需要根据关键字字符串构建一个KeywordList,所以如果keywords =“Compa”,我会返回带有粗体样式的“Comp”部分的“Company Name”,或者如果keywords =“Compa Nam”,则返回“Company”将“与”Compa Nam“命名为”大胆的风格等......
现在发生的事情是它无法在KeywordSearch中找到“Comp”部分。
有任何建议吗?
由于
答案 0 :(得分:1)
如果我没弄错,w.Contains(k.Name)
是关键部分。
w
是"Compa"
,k.Name
是KeywordSearch "Company"
和"Name"
。因此,您要问“Compa”是否包含“公司”或“名称”,这是错误的。
k.Name.Contains(w)
(或k.Name.StartsWith(w, StringComparison.CurrentCultureIgnoreCase)
如果您不希望区分大小写,则应返回正确的结果。