我很难找到有关如何使用C#中的Nest客户端搜索嵌套属性的信息。

我在索引中大致具有以下形状的电子邮件对象:

    {
      subject: “This is a test”,
      content: “This is an email written as a test of the Elasticsearch system.  Thanks, Mr Tom Jones”,
      custodians: [
        {
          firstName: “Tom”,
          lastName: “Jones”,
          routeType: 0
        },
        {
          firstName: “Matthew”,
          lastName: “Billsley”,
          routeType: 1
        }
      ]
    }

您应该能够看到其中有一个称为“保管人”的数组,该数组是电子邮件的所有发件人和收件人的列表。在.Net中使用Fluent风格的查询生成器时,我可以在使用主题,内容和其他“第一层”属性时很好地构建查询。但是我可能只想在某些查询中包括routeType = 0的保管人。我似乎找不到有关如何完成此操作的指导。有任何想法吗?

例如,在主题字段中对术语“野餐”的查询将类似于:
Client.SearchAsync(m => m
  .Query(q => q
    .Match(f => f
      .Field(msg => msg.Subject)
      .Query(“picnic”))));

仅从routeType = 0和lastName =“Jones”的索引中获取消息的查询将是什么?

仅供引用:这被交叉发布到Elasticsearch论坛。如果我在那里有个好的建议,我会在这里添加。

最佳答案

如果您想获取带有routeType == 0托管人的邮件:

Client.SearchAsync(m => m
  .Query(q => q
    .Term(t => t
      .Field(msg => msg.Custodians[0].RouteType)
      .Value(0))));

如果您想获取带有lastName == "jones"托管人的邮件:
Client.SearchAsync(m => m
  .Query(q => q
    .Term(t => t
      .Field(msg => msg.Custodians[0].LastName)
      .Value("jones"))));

如果要获取带有lastName == "jones"routeType == 0的托管人的邮件:
Client.SearchAsync(m => m
  .Query(q => q
    .Nested(t => t
      .Path(msg => msg.Custodians)
      .Query(nq =>
        nq.Term(t => t.Field(msg => msg.Custodians[0].RouteType).Value(0) &&
        ng.Term(t => t.Field(msg => msg.Custodians[0].LastName).Value("jones")
      )
    )
  )
);

请注意,custodians将需要映射为嵌套字段,以使最后一个查询按预期工作。有关嵌套字段的更多信息,请参见here

09-05 03:28