Elasticsearch(10)实践六-全文搜索

导言

本文将持续学习搜索相关的内容

全文搜索

目前为止搜索十分简单:单名,年龄过滤。让我们尝试一个更先进、全文搜索任务,这是传统的数据库很纠结的地方。

我们将搜索所有享受攀岩的员工:

GET /megacorp/employee/_search
{
    "query" : {
        "match" : {
            "about" : "rock climbing"
        }
    }
}

你可以看到,我们使用之前相同的match搜索对查询内容为“rock climbing”的 about字段。我们得到两个匹配文档信息:

{
   ...
   "hits": {
      "total":      2,
      "max_score":  0.16273327,
      "hits": [
         {
            ...
            "_score":         0.16273327, // --- (1)
            "_source": {
               "first_name":  "John",
               "last_name":   "Smith",
               "age":         25,
               "about":       "I love to go rock climbing",
               "interests": [ "sports", "music" ]
            }
         },
         {
            ...
            "_score":         0.016878016,  // --- (2)
            "_source": {
               "first_name":  "Jane",
               "last_name":   "Smith",
               "age":         32,
               "about":       "I like to collect rock albums",
               "interests": [ "music" ]
            }
         }
      ]
   }
}

这里写图片描述

默认情况下,Elasticsearch通过相关性系数得到类型匹配结果,也就是说,通过每个文档与查询匹配的匹配度有多好进行结果的返回。排名第一和高匹配度的结果是显而易见: John Smith’s about字段中清晰的看见“rock climbing”。
但是为什么Jane Smith作为一个结果返回?原因是她被返回的文档信息中“rock”该词在about域被提到。因为仅仅被提到了“rock”,而没有提到“climbing”,所以她的_score的值比John的低。
这是一个很好的例子,是关于Elasticsearch在全文字段中搜索并返回最相关的结果。Elasticsearch的相关性概念是很重要的,对传统的关系型数据库来说是一个完全陌生的概念,记录匹配与否。

实践

在sence中,输入如下的curl请求代码

curl -XGET "http://localhost:9200/megacorp/employee/_search" -d'
{
    "query" : {
        "match" : {
            "about" : "rock climbing"
        }
    }
}'

结果如图所示:

这里写图片描述

完整返回信息如下:

{
  "took": 448,
  "timed_out": false,
  "_shards": {
    "total": 5,
    "successful": 5,
    "failed": 0
  },
  "hits": {
    "total": 2,
    "max_score": 0.16273327,
    "hits": [
      {
        "_index": "megacorp",
        "_type": "employee",
        "_id": "1",
        "_score": 0.16273327,
        "_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": 0.016878016,
        "_source": {
          "first_name": "Jane",
          "last_name": "Smith",
          "age": 32,
          "about": "I like to collect rock albums",
          "interests": [
            "music"
          ]
        }
      }
    ]
  }
}

结语

全文搜索进行了一个大概的介绍,至于,到时候是否有具体实际的例子,还得待我有时间进行补充。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 PHP 中使用 ElasticSearch 进行商品搜索的最佳实践如下: 1. 安装 ElasticSearchElasticsearch-PHP 客户端库 要使用 ElasticSearch 进行搜索,首先需要安装 ElasticSearchElasticsearch-PHP 客户端库。可以使用 Composer 来安装 Elasticsearch-PHP 客户端库,例如:composer require elasticsearch/elasticsearch。 2. 创建索引 在 ElasticSearch 中,需要先创建一个索引,然后在该索引中创建一个或多个类型(type),最后将文档(document)添加到类型中。在 PHP 中,可以使用 Elasticsearch-PHP 客户端库来创建索引,例如:$client->indices()->create(['index' => 'my_index'])。 3. 添加文档 在 PHP 中使用 Elasticsearch-PHP 客户端库,可以使用 $client->index() 方法来添加文档到指定的类型中,例如:$client->index(['index' => 'my_index', 'type' => 'my_type', 'id' => 1, 'body' => ['name' => 'product1', 'price' => 10]])。 4. 进行搜索 在 PHP 中使用 Elasticsearch-PHP 客户端库进行搜索,可以使用 $client->search() 方法。例如,要搜索名称为“product1”的商品,可以使用以下代码: ``` $params = [ 'index' => 'my_index', 'type' => 'my_type', 'body' => [ 'query' => [ 'match' => [ 'name' => 'product1' ] ] ] ]; $response = $client->search($params); ``` 以上就是在 PHP 中使用 ElasticSearch 进行商品搜索的最佳实践。当然,还有很多其他的高级搜索技巧,例如使用聚合(aggregation)来计算平均价格、最高价格等等。可以根据具体的需求来逐步深入学习。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YuYunTan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值