我们尝试按标题字段对 Lucene 结果进行排序。
根据我对Lucene的理解,这需要NOT_ANALYZED领域。
从我在论坛上读到的内容来看,这也要求我们使用LowerCaseKeywordAnalyzer。(这里)
我不知道如何将它们放在一起,这就是我现在所拥有的,并且排序不起作用:
在 Sitecore.ContentSearch.Lucene.DefaultIndexConfiguration:
<fields hint="raw:AddCustomField">
<!--...-->
<field luceneName="titleForSorting" storageType="yes" indexType="untokenized">Title</field>
</fields>
我们的搜索结果类:
public class ContentSearchResultItem : SearchResultItem
{
public virtual string Title { get; set; }
[IndexField("titleForSorting")]
public virtual string TitleForSorting { get; set; }
}
我们的搜索实现:
using (var context = ContentSearchManager.GetIndex(Context.Indexname).CreateSearchContext())
{
var query = context.GetQueryable<ContentSearchResultItem>()
.Where(x => x.Title == "New York")
.OrderBy(x => x.TitleForSorting);
var searchResult = query.GetResults();
var hitsQuery = searchResult.Hits;
// Or sort here ??
// hitsQuery = hitsQuery.OrderBy(x => x.Document.TitleForSorting);
var results = hitsResults.Select(x => x.Document).ToArray();
}
如前所述,我还读到我们应该使用LowerCaseKeywordAnalyzer。但无法弄清楚在哪里配置它。似乎没有提供任何添加选项的地方。
欢迎任何帮助,谢谢!
你是对的,如果你对它进行最好的排序,该字段不会被标记化,因为如果你有空格等,它会将其分解成小标记并对其进行排序。
您可以在fieldMap
部分中将自定义分析器指定为field
元素的子元素..例如
<fieldNames hint="raw:AddFieldByFieldName">
<field fieldName="titleForSorting" storageType="YES" indexType="UN_TOKENIZED" vectorType="NO" boost="1f" type="System.String" settingType="Sitecore.ContentSearch.LuceneProvider.LuceneSearchFieldConfiguration, Sitecore.ContentSearch.LuceneProvider">
<analyzer type="Sitecore.ContentSearch.LuceneProvider.Analyzers.LowerCaseKeywordAnalyzer, Sitecore.ContentSearch.LuceneProvider" />
</field>
...
</fields>
(此版本自 Sitecore 7.0 修订版 130918 起有效)
对我有用的是添加 .在 where 子句之后列出
var query = context.GetQueryable<ContentSearchResultItem>()
.Where(x => x.Title == "New York")
.ToList()
.OrderBy(x => x.TitleForSorting);