gpt4 book ai didi

mysql - 将mysql查询转换为带或不带距离的 Elasticsearch 查询

转载 作者:行者123 更新时间:2023-11-29 15:34:56 25 4
gpt4 key购买 nike

我有以下 MySql 查询(伪),我需要将其转换为 Elasticsearch 查询

SELECT *
FROM Autos
WHERE Image!=null and (country="AUS" and distance < 50kms) or (Country="AUS" and City="")

任何人都可以帮我构建上面的 json Elastic Search 查询吗?

最佳答案

对于此解决方案,我将 bool 表达式组合重新排序为“图像 AND 国家/地区 AND(距离 OR 城市)”。

您可以使用存在查询来检查空值,使用范围查询来检查最大距离(考虑到您的距离存储在数字字段中),并使用术语查询来检查国家和城市。然后,您可以将它们与 bool 查询结合起来,以匹配上面显示的 bool 表达式:

{
"query": {
"bool": {
"must": [
{
"exists": { "field": "Image" }
},
{
"term": { "country" : { "value": "AUS" } }
},
{
"bool": {
"should": [
{
"range": { "distance": { "lt": "50" } }
},
{
"term": { "city": { "value": "" } }
}
]
}
}
]
}
}
}

关于mysql - 将mysql查询转换为带或不带距离的 Elasticsearch 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58342374/

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