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

标签 mysql elasticsearch

我有以下 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/

相关文章:

mysql - 将整数变量传递给 MySql select 语句

php - 为什么我的触发器无法在 mysql 5.7 中创建?

elasticsearch - 与Elasticsearch的比率

search - ElasticSearch可以在单个查询中删除所有内容并插入新文档吗?

mysql - Yii 中的子查询

mysql - 弃用警告 : A boolean value was passed to options. 运算符别名。这是 v5 的无操作,应删除

python - 如何在Python的 Elasticsearch 中搜索多个OR条件

.net - 在 Serilogs Elasticsearch Sink 中使用 IndexDecider

elasticsearch - 我应该如何索引和搜索英文连字符?

mysql - 为什么从 Ruby 通过 Mysql2 传递一个日期查询可以工作,而另一个则不行?