我当前正在使用.Net Core 2.2,并且一直在使用Microsoft.Azure.Search.Model程序包来使用Azure搜索。
问题:我不区分大小写无法实现OrderBy。
我进行了一些研究,但是除了在搜索索引上创建其他字段(包括原始字段的所有小写字符串字段)之外,我无法找到干净的解决方案。我不喜欢这种解决方案,因为我们需要订购6个以上的字段。就是说,我们将有6个附加字段仅用于排序搜索索引,这对我来说并不是一个最佳解决方案。
public override async Task<DocumentSearchResult<ProjectSearchModel>> SearchAsync(ISearchRequest input)
{
if (input is ProjectSearchRequest request)
{
var parameters =
new SearchParameters(includeTotalResultCount: true)
{
Filter = request.Status.Equals("All") ? $"Account eq '{request.Account}'" : $"Account eq '{request.Account}' and Status eq '{request.Status}'",
OrderBy = new[] { $"Account desc" },
Top = request.Take,
Skip = request.Skip
};
var searchResult = await base.SearchAsync(parameters, request.Text);
return searchResult;
}
else
{
throw new Exception("Account code is necessary for search in projects. ProjectSearchRequest -> ISearchRequest casting error.");
}
}
响应按帐户排序,但大写在前,小写在后。 例如,z会在A后面,这对于我们的最终用户没有意义。我希望z紧随Z或与Z一起出现。
答案 0 :(得分:0)
不幸的是,您建议的选项(在OrderBy中使用额外的大小写标准化字段)是唯一的解决方法。您将使用令牌过滤器将该字段小写-https://docs.microsoft.com/en-us/azure/search/index-add-custom-analyzers#token-filters
请在此处投票,以便搜索团队可以优先选择它: https://feedback.azure.com/forums/263029-azure-search/suggestions/6328658-case-insensitive-sorting-for-string-fields