NEST ElasticSearch Guid 问题

NEST ElasticSearch Guid problems

我在过滤字段 Guid 上的查询时遇到了一些问题。这是我的代码示例。我错过了什么?

public class myObject 
{
  public Guid Id {get;set}
  public String Field1 { get; set; }
  public String Field2 { get; set; }
  public String Fieldn { get; set; }
  public ReadingRightsEnum ReadingRights { get; set; }
  public Guid UserId { get; set; }
}

// Index fct example
public void IndexMyObject(obj)
{
   var result = await myClient.IndexAsync(obj, i => i
                              .Index("myIndexName")
                              .Type("myObject")
                              .Id(obj.Id.ToString())
                              .Refresh());
}

// Index fct example
public void SearchOnlyInMyUserObject(string userQuery, Guid userId)
{
    var searchResult = await myClient.SearchAsync<myObject>(body =>
        body.Query(q => 
            q.QueryString(qs => qs.MinimumShouldMatchPercentage(100).Query(userQuery))
            && q.Term(i => i.UserId, userId))
        .Fields(f => f.Id)
        .Size(200));
}

// Index fct example with filter
public void SearchOnlyInMyUserObject(string userQuery, Guid userId)
{
    var filters = new List<FilterContainer>
    {
         new FilterDescriptor<myObject>().Bool(b => b.Must(m => m.Term(i => i.UserId, userId)));
    };
    var searchResult = await myClient.SearchAsync<myObject>(body =>
        body
        .Filter(f => f.And(filters.ToArray()))
        .Query(q => 
            q.QueryString(qs => qs.MinimumShouldMatchPercentage(100).Query(userQuery)))
        .Fields(f => f.Id)
        .Size(200));
}

如果我对其他参数进行过滤,这两个函数都可以正常工作,但return当我对 Guid 进行过滤时,则没有任何效果。当我索引我的对象时,是否应该将我的 Guid 转换为字符串?

如果我这样做 http://xxxxxxx:9200/_search?q=userId:e4aec7b4-c400-4660-a09e-a0ce064f612e 它工作正常。

有什么想法吗?

提前致谢

在此处编辑 06/12 myindex 示例:

myIndexName":{
    "mappings":{
        "myObject":{
            "properties":{
                "readingrights":{
                    "type":"integer"
                },
                "id":{
                    "type":"string"
                },
                "field1":{
                    "type":"string"
                },      
                "field2":{
                    "type":"string"
                },                
                "userId":{
                    "type":"string"
                }
            }
        }
    }
}

我现在不明白为什么 Guid 会遇到问题...但我现在可以找到一个糟糕的替代方法: 而不是:

q.QueryString(qs => qs.MinimumShouldMatchPercentage(98).Query(userQuery))
&& q.Term(i => i.UserId, userId)

我做了一个双 QueryString:

q.QueryString(qs => qs.MinimumShouldMatchPercentage(98).Query(userQuery))
&& q.QueryString(qs => qs.MinimumShouldMatchPercentage(100).Query(" \"" + userId+ "\""))

GUID 字段在 Elastic 中很棘手。如果你使用弹性客户端的分析功能,它会告诉你它是如何分解一个 GUID 的。 AnalyzeRequest obj = new AnalyzeRequest(_index, item); _client.Analyze(对象);

创建实体时,需要将guid定义为不被解析。 [字符串(索引= FieldIndexOption.NotAnalyzed)] public Guid TextAssetId