C# ElasticSearch NEST,复合聚合脚本转换错误
C# ElasticSearch NEST, Composite aggregation script casting error
我是 ElasticSearch 的新手,它是 C# 的 NEST 客户端。
显然复合聚合的 min_doc_count 没有实现,我应该在请求中使用脚本来实现结果,参见:https://github.com/elastic/elasticsearch/issues/32452#issuecomment-408769861.
然而,当我尝试在 C# 中实现它时,出现以下错误:
"Type: class_cast_exception Reason: "Cannot cast from [boolean] to [java.lang.Number].""
我的代码如下所示:
ISearchResponse<FooBar> duplicateBucket = _elasticClient.Search<FooBar>(
s => s
.Aggregations(a => a
.Composite("dupe_bucket", c => c
.Sources(b => b
.Terms("foo", x => x
.Field("foo"))
.Terms("bar", x => x
.Field("bar")))
.Size(1000)
.Aggregations(e => e
.BucketScript("bucket_selector", d => d
.BucketsPath(f => f
.Add("counter", "_count"))
.Script("params.counter > 1"))))));
如果我删除第二个聚合,调用就会成功,很明显我在 BucketScript 部分做错了。
如有任何帮助,我们将不胜感激!
我想你想使用 BucketSelector
而不是 BucketScript
.Aggregations(e => e
--> .BucketSelector("bucket_selector", d => d
.BucketsPath(f => f
.Add("counter", "_count"))
.Script("params.counter > 1"))))));
我是 ElasticSearch 的新手,它是 C# 的 NEST 客户端。 显然复合聚合的 min_doc_count 没有实现,我应该在请求中使用脚本来实现结果,参见:https://github.com/elastic/elasticsearch/issues/32452#issuecomment-408769861.
然而,当我尝试在 C# 中实现它时,出现以下错误:
"Type: class_cast_exception Reason: "Cannot cast from [boolean] to [java.lang.Number].""
我的代码如下所示:
ISearchResponse<FooBar> duplicateBucket = _elasticClient.Search<FooBar>(
s => s
.Aggregations(a => a
.Composite("dupe_bucket", c => c
.Sources(b => b
.Terms("foo", x => x
.Field("foo"))
.Terms("bar", x => x
.Field("bar")))
.Size(1000)
.Aggregations(e => e
.BucketScript("bucket_selector", d => d
.BucketsPath(f => f
.Add("counter", "_count"))
.Script("params.counter > 1"))))));
如果我删除第二个聚合,调用就会成功,很明显我在 BucketScript 部分做错了。
如有任何帮助,我们将不胜感激!
我想你想使用 BucketSelector
而不是 BucketScript
.Aggregations(e => e
--> .BucketSelector("bucket_selector", d => d
.BucketsPath(f => f
.Add("counter", "_count"))
.Script("params.counter > 1"))))));