5

我们将 elastic4s 用于 ElasticSearch 2.2.0。许多查询以 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弹性搜索 REST 客户端为匹配返回3.075806的分数。

4

1 回答 1

1

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

就像你会查询

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

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

或者,您可以尝试使用extraSource而不是rawQuery,如 elastic4s 文档中所述。虽然它根本不适合我:

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

于 2016-08-26T12:20:57.143 回答