ElasticSearch NEST return 个特定字段

ElasticSearch NEST return specific fields

我正在尝试编写一个只返回其中一个字段的查询。现在我正在存储文件的文件路径和文件的内容,在我的搜索中我想搜索内容,但只有 return 文件路径。

我从这个声明开始:

var searchResults = client.Search<File>(
        s => s.Query(q => q.Wildcard(w => w.Value("*" + genre + "*").OnField("fileContents"))).AllIndices().AllTypes());

returns 导致 searchResults.Documents 并向其添加 .Fields:

var searchResults = client.Search<File>(
        s => s.Query(q => q.Wildcard(w => w.Value("*" + genre + "*").OnField("fileContents"))).AllIndices().AllTypes().Fields(f=>f.filePath));

它在 searchResults.Documents 中没有任何内容,但它使用 searchResults.Hits.Total.

正确显示了命中数

文件 class 只是:

public class File
{
  public string filePath { get; set; }
  public string fileContents { get; set; }
}  

这会生成以下 json 请求:

{
"fields": [
"filePath"
],
"query": {
    "wildcard": {
     "fileContents": {
        "value": "*int*"
      }
    }
  }
}

当 运行 在 Sense returns 的结果和当做 searchResults.Hits.Total 给出命中数时。

但是,searchResults.Document IEnumerable 中没有记录。

有没有其他方法可以让我 return 进入一个特定的领域?

使用"source" 字段指定要撤回的字段。这是我的应用程序的示例代码,其中只有 returns 一些字段。

        var searchResults = ElasticClient.Search<AuthForReporting>(s => s
            .Size(gridSortData.PageSize)
            .From(gridSortData.PageIndex * gridSortData.PageSize)
            .Sort(sort)
            .Source(sr => sr
                .Include(fi => fi
                    .Add(f => f.AuthEventID)
                    .Add(f => f.AuthResult.AuthEventDate)
                    .Add(f => f.AuthInput.UID)
                    .Add(f => f.AuthResult.CodeID)
                    .Add(f => f.AuthResult.AuthenticationSuccessful)
                    .Add(f => f.AuthInput.UserName)
                    .Add(f => f.AuthResult.ProductID)
                    .Add(f => f.AuthResult.ProductName)
                    .Add(f => f.AuthInput.AuthType)
                    .Add(f => f.AuthResult.Address.City)
                    .Add(f => f.AuthResult.Address.State)
                    .Add(f => f.AuthResult.Address.CountryCode)
                    .Add(f => f.AuthResult.RulesFailed)
                )
            )
            .Query(query)
        );

然后您通过结果中的 "source" 访问字段:

            var finalResult = from x in searchResults.Hits
                   select new AlertListRow
                          {
                              AlertCode = x.Source.AlertCode,
                              AlertDate = x.Source.AlertDate,
                              AlertID = x.Id,
                              AlertSummary = x.Source.Subject,
                              AlertMessage = x.Source.Body
                          };