ElasticSearch的搜索方式

目录

目录

前言

数据准备

文档搜索

一、查询所有文档

二、全文检索

(1)全文检索

(2)自动纠错

三、范围搜索

四、短语检索

五、单词/词组搜索

六、复合搜索


前言

数据准备

javascript 复制代码
PUT /students
{
  "mappings":{
    "properties":{
      "id": {
            "type": "integer",
        "index": true
       },
         "name": {
            "type": "text",
            "store": true,
        "index": true,
            "analyzer": "ik_smart"
         },
      "info": {
            "type": "text",
            "store": true,
        "index": true,
            "analyzer": "ik_smart"
         }
     }
   }
}


POST /students/_doc/
{
 "id":1,
 "name":"程序员",
 "info":"I love you"
}


POST /students/_doc/
{
 "id":2,
 "name":"美羊羊",
 "info":"美羊羊是羊村最漂亮的人"
}


POST /students/_doc/
{
 "id":3,
 "name":"懒羊羊",
 "info":"懒羊羊的成绩不是很好"
}


POST /students/_doc/
{
 "id":4,
 "name":"小灰灰",
 "info":"小灰灰的年纪比较小"
}


POST /students/_doc/
{
 "id":5,
 "name":"沸羊羊",
 "info":"沸羊羊喜欢美羊羊"
}


POST /students/_doc/
{
 "id":6,
 "name":"灰太狼",
 "info":"灰太狼是小灰灰的父亲,每次都会说我一定会回来的"
}

文档搜索

javascript 复制代码
GET /索引/_search
{
    "query":{
    搜索方式:搜索参数
   }
}

一、查询所有文档

javascript 复制代码
{
    "query":{
    "match_all":{}
   }
}

二、全文检索

(1)全文检索

javascript 复制代码
{
    "query":{
    "match":{
      搜索字段:搜索条件
     }
   }
}

(2)自动纠错

注:在搜索时关键词有可能会输入错误,ES搜索提供了自动纠错功能,即ES的模糊查询。使用match方式可以实现模糊查询。模糊查询对中文的支持效果一般,我们使用英文数据测试模糊查询。

javascript 复制代码
{
    "query": {
        "match": {
            "域名": {
            "query": 搜索条件,
            "fuzziness": 最多错误字符数,不能超过2
            }
        }
    }
}

三、范围搜索

范围搜索。对数字类型的字段进行范围搜索

javascript 复制代码
{
    "query":{
    "range":{
      搜索字段:{ 
        "gte":最小值,
        "lte":最大值
       } 
     }
   }
}
gt/lt:大于/小于
gte/lte:大于等于/小于等于

四、短语检索

搜索条件不做任何分词解析,在搜索字段对应的倒排索引中精确匹配。

javascript 复制代码
{
    "query":{
    "match_phrase":{
      搜索字段:搜索条件
     }
   }
}

五、单词/词组搜索

term/terms:单词/词组搜索。搜索条件不做任何分词解析,在搜索字段对应的倒排索引中精确匹配

javascript 复制代码
{
    "query":{
    "term":{ 
            搜索字段: 搜索条件
     }
   }
}


{
    "query":{
    "terms":{ 
            搜索字段: [搜索条件1,搜索条件2]
     }
   }
}

六、复合搜索

简单来说就是支持多个条件搜索,有三个:必须满足,满足其中一个,必须都不满足!

javascript 复制代码
GET /索引/_search
{ 
    "query": { 
    "bool": { 
      // 必须满足的条件 
      "must": [ 
                搜索方式:搜索参数,
                搜索方式:搜索参数
       ],
      // 多个条件有任意一个满足即可
      "should": [
                搜索方式:搜索参数,
               搜索方式:搜索参数
           ],
            // 必须不满足的条件
           "must_not":[
               搜索方式:搜索参数,
               搜索方式:搜索参数
           ]
       } 
   } 
}

举例:

必须有"成绩"关键字,而且id是大于等于1小于等于3(可以多个条件一起的,如必须满足什么,必须不满足什么)

javascript 复制代码
GET /students/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "term": {
            "info":"成绩"
          }
        },
        {
          "range":{
            "id":{
              "gte": 1,
              "lte": 3
            }
          }
        }
      ]
    }
  }
}
相关推荐
徐先生 @_@|||1 分钟前
基于Spark配置+缓存策略+Junpyter Notebook 实现Spark数据加速调试
大数据·分布式·缓存·spark
合新通信 | 让光不负所托2 分钟前
边缘计算节点空间受限,用浸没式液冷光模块能同时满足小型化和高性能需求吗?
大数据·人工智能·阿里云·云计算·边缘计算
方向研究5 分钟前
金价上涨
大数据
智子喻10 分钟前
2026企业微信社群运营工具专业度排名:AI驱动下的私域增长工具实测
大数据·网络·新媒体运营·企业微信·用户运营
故乡de云16 分钟前
Gemini API的数据隔离:企业级AI应用的安全感从哪来?
大数据·人工智能
☀Mark_LY35 分钟前
elasticsearch7集群Linux部署
linux·elasticsearch
秃了也弱了。35 分钟前
elasticSearch之API:文本分词,分词器的使用(上)
大数据·elasticsearch
徐先生 @_@|||41 分钟前
大数据技术栈演进:从MapReduce到云原生计算的全面对比(2026年)
大数据·hadoop·云原生·spark·mapreduce
TechubNews43 分钟前
巨鲸入海:纽交所代币化证券平台瞄准全天候交易与即时结算
大数据·人工智能
徐先生 @_@|||44 分钟前
大数据处理框架(Hadoop VS PySpark)
大数据·hadoop·分布式·spark·k8s·yarn