gpt4 book ai didi

scala - elastic4s:rawQuery 得分保持在 1

转载 作者:行者123 更新时间:2023-11-29 02:50:26 25 4
gpt4 key购买 nike

我们在 ElasticSearch 2.2.0 中使用 elastic4s。许多查询以 JSON 格式存储在磁盘上,并通过 elastic4s 驱动程序用作 rawQuery。结果中的分数在通过命令行或 elastic4s 驱动程序提交的查询之间有所不同。 elastic4s 驱动程序始终为所有结果返回 1 的分数,而命令行执行会产生两个不同的分数(针对不同的数据类型)。

elastic4s的代码:

   val searchResult = client.execute {
search in indexName types(product, company, orga, "User", "Workplace") rawQuery preparedQuery sourceInclude(preparedSourceField:_*) sort {sortDefintions:_*} start start limit limit
}.await

请注意,我删除了除 rawQuery preparedQuery 之外的任何内容,它并没有改变分数 1。通过命令行的完整查询非常长:

{
"query": {
"bool": {
"must": [
{
"multi_match": {
"query": "${search}",
"fields": [
"name",
"abbreviation",
"articleNumberManufacturer",
"productLine",
"productTitle^10",
"productSubtitle",
"productDescription",
"manufacturerRef.name",
"props"
]
}
}
],
"filter": [
{
"or": [
{
"bool": {
"must": [
{
"type": {
"value": "Product"
}
},
{
"term": {
"publishState": "published"
}
}
],
"must_not": [
{
"term": {
"productType": "MASTER"
}
},
{
"term": {
"deleted": true
}
}
]
}
}
]
}
]
}
}
}

请注意,这几乎是 preparedQuery,但用于将 $search 替换为搜索查询。 Elasticsearch REST 客户端返回匹配项的分数 3.075806

最佳答案

elastic4s rawQuery 会将您的 rawQuery-JSON 包装在另一个查询对象中。

这就像你要查询

{ "query": { "query": {     
"bool": {
"must": [
{
"multi_match": {
"query": "${search}",
...

只需从 JSON 中删除包装“查询”,响应就会显示不同的分数。

或者,您可以尝试使用 extraSource 而不是 rawQuery,如 elastic4s docu 中所述。尽管它对我根本不起作用:

错误信息:值 extraSource 不是 com.sksamuel.elastic4s.SearchDefinition 的成员

关于scala - elastic4s:rawQuery 得分保持在 1,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36864137/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com