首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Elastic Search 1.7 - Full Like search like SQL

Elastic Search 1.7 - Full Like search like SQL
EN

Stack Overflow用户
提问于 2019-06-27 15:29:00
回答 1查看 31关注 0票数 0

我正在使用旧版本的弹性搜索,但我找不到一种方法来允许像sql:'%%‘这样的完整like搜索

我必须搜索一个未知的数据,所以“列”是未知的。

例如。我有这个列和一个行的例子:

代码语言:javascript
复制
source,dest,message
eth0, eth1, DELIVERY 3015801: SUCCESS: DID

在搜索表单中,用户编写如下内容:

代码语言:javascript
复制
+message:"delivery"
or
+message:"delivery" and +source:"eht0"

成功返回该行。不幸的是,如果他们写道:

代码语言:javascript
复制
+message:"success"

由于":“,它不返回任何行。

我需要允许用户写一些像这样的东西:

代码语言:javascript
复制
+message:"success*"

这是提交的查询。我有timerange过滤器,然后是查询:

代码语言:javascript
复制
{
  "query": {
    "filtered": {
      "filter": {
        "bool": {
          "must": [
            {
              "range": {
                "@timestamp": {
                  "from": 1561615860000,
                  "to": 1561619519000
                }
              }
            }
          ]
        }
      },
      "query": {
        "bool": {
          "should": [
            {
              "query_string": {
                "query": "+message:\"success\""
              }
            }
          ]
        }
      }
    }
  },
  "sort": [
    {
      "@timestamp": {
        "order": "desc"
      }
    }
  ]
}

有没有办法把我的文本搜索翻译成像sql这样的东西?

代码语言:javascript
复制
message like 'success%'

谢谢。

EN

回答 1

Stack Overflow用户

发布于 2019-06-27 21:54:25

这是一个已分析的字段还是未分析的字段?也许prefix query就是你想要的。

但通常情况下:

  • 这个版本已经不复存在了。请升级。
  • 这不是关系数据库。如果你试图1:1地翻译概念,你不会得到最大的收获。文档或课程将帮助您进入正确的搜索,而不是LIKE搜索。
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56786067

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档