如何解决使用 NEST 在多个弹性搜索索引中搜索
我正在尝试使用 nest 7.10.1 在 elasticsearch 中搜索文本。我想搜索两个不同的索引,得到文档形式的响应,但我无法访问其属性,因为结果具有两个索引的组合。下面是我试过的代码。两个索引具有相同的属性。我在 foreach 循环中使用什么来访问结果文档的键和值。
public void searchindices(string query) {
var response = client.Search<object>(
s => s.Index("kNowledgearticles_index,index2")
.Query(q => q.Match(m => m.Field("locationName")
.Query(query))));
Console.WriteLine(response.Documents);
foreach(object r in response.Documents) {
}
}
我使用的是 elasticsearch 7.10.2
解决方法
the search response 中返回的每个原始命中都有与之关联的 _index
meta field:
"hits" : {
"total" : {
"value" : 91,"relation" : "eq"
},"hits" : [
{
"_index" : "knowledgearticles_index",<---
"_type" : "_doc","_id" : "r_oLl3cBZOT6A8Qby8Qd","_score" : 1.0,"_source" : {
...
}
}
现在,在 NEST 中,
.Documents
是检索每次命中的 _source
的便捷简写
-- 意味着您将无法访问元属性。
所以诀窍是use a loop像这样:
foreach (var hit in response.HitsMetadata.Hits) {
Console.WriteLine(hit);
}
,
如果您搜索的两个索引包含不同的 JSON 结构,则 T
中的 Search<T>
将需要是不同 JSON 结构可以反序列化为的类型。 object
将按照您问题中的示例工作,但是对于任何属性都没有类型化访问权限。
克服这个问题的一个简单方法是hook up the JsonNetSerializer
,然后将JObject
用于T
var pool = new SingleNodeConnectionPool(new Uri("http://localhost:9200"));
var connectionSettings =
new ConnectionSettings(pool,sourceSerializer: JsonNetSerializer.Default);
var client = new ElasticClient(connectionSettings);
var response = client.Search<JObject>(s => s
.Index("knowledgearticles_index,index2")
.Query(q => q
.Match(m => m
.Field("locationName")
.Query(query)
)
)
);
我们现在可以访问 JObject
上的属性,但仍需要处理每个属性的类型。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。