弹性NEST中子文档的关键字映射
Keyword mapping for sub document in elastic NEST
我现在学习 Nest 6.x elasticsearch 客户端 我想在子文档中使用术语搜索。我有这个 类:
public class BaseTest
{
public string Id { get; set; }
public SubBase SubDocument { get; set; }
public Guid TypeId { get; set; }
public string BaseTitel { get; set; }
}
public class SubBase
{
public int Id { get; set; }
public Guid IdGuid { get; set; }
public string Titel { get; set; }
}
并使用此映射创建索引:
.Mappings(mp => mp
.Map<BaseTest>(m => m
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.BaseTitel)))
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.TypeId)))
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.SubDocument.Titel)))
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.SubDocument.IdGuid)
))))
wenn 我尝试在 BaseTest 中搜索 GUID(或 GUID 格式的字符串,我将 SubBase.Titel 保存为 Guid 用于测试)值它有效,但在 SubBase 中无效。
要搜索,我使用此查询:
.Query(q => q
.ConstantScore(cs => cs
.Filter(f => f
.Term(t => t
.SubDocument.Titel, "5d511b8a-37c7-40c1-a5c3-4de13e16e379"))))
更新
新映射:
.Mappings(mp => mp
.Map<BaseTest>(m => m
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.BaseTitel)
.Name(nm => nm.TypeId)
)
.Object<SubBase>(o => o
.Name(n => n.SubDocument)
.Properties(p => p
.Keyword(k => k
.Name(n => n.Titel)
.Name(n => n.IdGuid)))))))
现在我可以找到 Guid 属性,但找不到类型为字符串的 属性 值,如“5d511b8a-37c7-40c1-a5c3-4de13e16e379”
谢谢 Russ Cam
.Mappings(mp => mp
.Map<BaseTest>(m => m
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.BaseTitel))
.Keyword(kw => kw
.Name(nm => nm.TypeId))
.Object<SubBase>(o => o
.Name(n => n.SubDocument)
.Properties(p => p
.Keyword(k => k
.Name(n => n.Titel))
.Keyword(k => k
.Name(n => n.IdGuid)))))))
我现在学习 Nest 6.x elasticsearch 客户端 我想在子文档中使用术语搜索。我有这个 类:
public class BaseTest
{
public string Id { get; set; }
public SubBase SubDocument { get; set; }
public Guid TypeId { get; set; }
public string BaseTitel { get; set; }
}
public class SubBase
{
public int Id { get; set; }
public Guid IdGuid { get; set; }
public string Titel { get; set; }
}
并使用此映射创建索引:
.Mappings(mp => mp
.Map<BaseTest>(m => m
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.BaseTitel)))
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.TypeId)))
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.SubDocument.Titel)))
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.SubDocument.IdGuid)
))))
wenn 我尝试在 BaseTest 中搜索 GUID(或 GUID 格式的字符串,我将 SubBase.Titel 保存为 Guid 用于测试)值它有效,但在 SubBase 中无效。 要搜索,我使用此查询:
.Query(q => q
.ConstantScore(cs => cs
.Filter(f => f
.Term(t => t
.SubDocument.Titel, "5d511b8a-37c7-40c1-a5c3-4de13e16e379"))))
更新
新映射:
.Mappings(mp => mp
.Map<BaseTest>(m => m
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.BaseTitel)
.Name(nm => nm.TypeId)
)
.Object<SubBase>(o => o
.Name(n => n.SubDocument)
.Properties(p => p
.Keyword(k => k
.Name(n => n.Titel)
.Name(n => n.IdGuid)))))))
现在我可以找到 Guid 属性,但找不到类型为字符串的 属性 值,如“5d511b8a-37c7-40c1-a5c3-4de13e16e379”
谢谢 Russ Cam
.Mappings(mp => mp
.Map<BaseTest>(m => m
.Properties(pr => pr
.Keyword(kw => kw
.Name(nm => nm.BaseTitel))
.Keyword(kw => kw
.Name(nm => nm.TypeId))
.Object<SubBase>(o => o
.Name(n => n.SubDocument)
.Properties(p => p
.Keyword(k => k
.Name(n => n.Titel))
.Keyword(k => k
.Name(n => n.IdGuid)))))))