elasticsearch搜索
搜索
检索单个文档
现在Elasticsearch中已经存储了一些数据,我们可以根据业务需求开始工作了。第一个需求是能够检索单个员工的信息。
这对于Elasticsearch来说非常简单。我们只要执行HTTP GET请求并指出文档的“地址”——索引、类型和ID既可。根据这三部分信息,我们就可以返回原始JSON文档:
GET /megacorp/employee/1
响应的内容中包含一些文档的元信息,John Smith的原始JSON文档包含在_source字段中。
{
  "_index" :  "megacorp",
  "_type" :    "employee",
  "_id" :      "1",
  "_version" : 1,
  "found" :    true,
  "_source" :  {
      "first_name" :  "John",
      "last_name" :  "Smith",
      "age" :        25,
      "about" :      "I love to go rock climbing",
      "interests":  [ "sports", "music" ]
  }
}
我们通过HTTP方法GET来检索文档,同样的,我们可以使用DELETE方法删除文档,使用HEAD方法检查某文档是否存在。如果想更新已存在的文档,我们只需再PUT一次。
搜索全部文档
我们尝试一个最简单的搜索全部员工的请求:
GET /megacorp/employee/_search
你可以看到我们依然使用megacorp索引和employee类型,但是我们在结尾使用关键字_search来取代原来的文档ID。响应内容的hits数组中包含了我们所有的三个文档。默认情况下搜索会返回前10个结果。
{
字符串是什么字段类型  "took":      6,
  "timed_out": false,
  "_shards": { ... },
  "hits": {
      "total":      3,
      "max_score":  1,
      "hits": [
        {
            "_index":        "megacorp",
            "_type":          "employee",
            "_id":            "3",
            "_score":        1,
            "_source": {
              "first_name":  "Douglas",
              "last_name":  "Fir",
              "age":        35,
              "about":      "I like to build cabinets",
              "interests": [ "forestry" ]
            }
        },
        {
            "_index":        "megacorp",
            "_type":          "employee",
            "_id":            "1",
            "_score":        1,
            "_source": {
              "first_name":  "John",
              "last_name":  "Smith",
              "age":        25,
              "about":      "I love to go rock climbing",
              "interests": [ "sports", "music" ]
            }
        },
        {
            "_index":        "megacorp",
            "_type":          "employee",
            "_id":            "2",
            "_score":        1,
            "_source": {
              "first_name":  "Jane",
              "last_name":  "Smith",
              "age":        32,
              "about":      "I like to collect rock albums",
              "interests": [ "music" ]
            }
        }
      ]
  }
}
注意:
响应内容不仅会告诉我们哪些文档被匹配到,而且这些文档内容完整的被包含在其中—我们在给用户展示搜索结果时需要用到的所有信息都有了。
搜索姓氏中包含Smith的员工
要做到这一点,我们将在命令行中使用轻量级的搜索方法。这种方法常被称作查询字符串(query string)搜索,因为我们像传递URL参数一样去传递查询语句:
GET /megacorp/employee/_search?q=last_name:Smith
我们在请求中依旧使用_search关键字,然后将查询语句传递给参数q=。这样就可以得到所有姓氏为Smith的结果:
{
  ...
  "hits": {
      "total":      2,
      "max_score":  0.30685282,
      "hits": [
        {
            ...
            "_source": {
              "first_name":  "John",
              "last_name":  "Smith",
              "age":        25,
              "about":      "I love to go rock climbing",
              "interests": [ "sports", "music" ]
            }
        },
        {
            ...
            "_source": {
              "first_name":  "Jane",
              "last_name":  "Smith",
              "age":        32,
              "about":      "I like to collect rock albums",
              "interests": [ "music" ]
            }
        }
      ]
  }
}
DSL语句查询
查询字符串搜索便于通过命令行完成特定(ad hoc)的搜索,但是它也有局限性(参阅简单搜索章节)。Elasticsearch提供丰富且灵活的查询语言叫做DSL查询(Query DSL),它允许你构建更加复杂、强大的查询。
DSL(Domain Specific Language特定领域语言)以JSON请求体的形式出现。我们可以这样表示之前关于“Smith”的查询:
GET /megacorp/employee/_search
{
    "query" : {
        "match" : {
            "last_name" : "Smith"
        }
    }
}
这会返回与之前查询相同的结果。你可以看到有些东西改变了,我们不再使用查询字符串(q
uery string)做为参数,而是使用请求体代替。这个请求体使用JSON表示,其中使用了match语句(查询类型之一,具体我们以后会学到)。
更复杂的搜索
我们让搜索稍微再变的复杂一些。我们依旧想要到姓氏为“Smith”的员工,但是我们只想得到年龄大于30岁的员工。我们的语句将添加过滤器(filter),它使得我们高效率的执行一个结构化搜索:
GET /megacorp/employee/_search
{
    "query" : {
        "filtered" : {
            "filter" : {
                "range" : {
                    "age" : { "gt" : 30 } <1>
                }
            },
            "query" : {
                "match" : {
                    "last_name" : "smith" <2>
                }
            }
        }
    }
}
<1> 这部分查询属于区间过滤器(range filter),它用于查所有年龄大于30岁的数据——gt为"greater than"的缩写。
<2> 这部分查询与之前的match语句(query)一致。
现在不要担心语法太多,我们将会在以后详细的讨论。你只要知道我们添加了一个过滤器(filter)用于执行区间搜索,然后重复利用了之前的match语句。现在我们的搜索结果只显示了一个32岁且名字是“Jane Smith”的员工:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。