【Elasticsearch】05-DSL查询

1. 查询所有

es最多只支持查询1万条数据。

java 复制代码
# 查询所有
GET /items/_search
{
  "query": {
    "match_all": {}
  }
}

2. 叶子查询

    1. 全文检索

会对结果进行相关度打分。

java 复制代码
# 检索单个字段
GET /items/_search
{
  "query": {
    "match": {
      "name": "脱脂牛奶"
    }
  }
}

# 检索多个字段
GET /items/_search
{
  "query": {
    "multi_match": {
      "query": "TEXT",
      "fields": ["FIELD1", "FIELD2"]
    }
  }
}
    1. 精确查询

Term-level query,推荐查找keyword、数值、日期、boolean类型的字段。

java 复制代码
# 精确查询
GET /items/_search
{
  "query": {
    "term": {
      "isAD": {
        "value": "true"
      }
    }
  }
}
java 复制代码
# range查询
GET /items/_search
{
  "query": {
    "range": {
      "price": {
        "gte": 100,
        "lte": 200
      }
    }
  }
}
java 复制代码
# ids所有
GET /items/_search
{
  "query": {
    "ids": {
      "values": ["3070884", "4208291"]
    }
  }
}

3. 复合查询

filter也是与,但条件不参与算分。

java 复制代码
GET /items/_search
{
  "query": {
    "bool": {
      "must": [
        {"match": {
          "name": "手机"
        }}
      ],
      "should": [
        {"term": {
          "brand": {
            "value": "vivo"
          }
        }},
        {
          "term": {
            "brand": {
              "value": "小米"
            }
          }
        }
      ],
      "must_not": [
        {"range": {
          "price": {
            "gte": 5000
          }
        }}
      ],
      "filter": [
        {"range": {
          "price": {
            "lte": 1000
          }
        }}
      ]
    }
  }
}

4. 排序

排序设置后,不会打分。

分页使用from,size。

java 复制代码
# 排序查询
GET /items/_search
{
  "query": {
    "match_all": {}
  },
  "from": 0,
  "size": 20, 
  "sort": [
    {
      "sold": "desc"
    },
    {
      "price": "asc"
    }
  ]
}

5. 分页

方案:

  • search after:分页时需要排序,是从上一次的排序值开始,查询下一页数据。

6. 高亮显示

java 复制代码
# 排序查询
GET /items/_search
{
  "query": {
    "match": {
      "name": "手机"
    }
  },
  "highlight": {
    "fields": {
      "name": {
        "pre_tags": "<em>",
        "post_tags": "</em>"
      }
    }
  }
}
相关推荐
一个大专生的淘汰之路31 分钟前
Elasticsearch 如何确保新增文档立即可见?
elasticsearch
金融小师妹32 分钟前
基于NLP政策信号解析的联邦基金利率预测:美银动态调整12月降息概率至88%,2026年双降路径的强化学习模拟
大数据·人工智能·深度学习·1024程序员节
新诺韦尔API1 小时前
手机空号检测接口对接全流程指南
大数据·网络·智能手机·api
知秋正在9962 小时前
ElasticSearch服务端报错:system call filters failed to install
大数据·elasticsearch·搜索引擎
ASTHENIA2 小时前
HNUST-2025年秋-软件工程复习资料
大数据·软件工程
Elasticsearch3 小时前
Elastic Streams 介绍
elasticsearch
金融小师妹3 小时前
基于LSTM趋势预测的白银价格突破58美元阈值,年度累计涨幅超100%的强化学习驱动分析
大数据·人工智能·编辑器·1024程序员节
DashVector3 小时前
如何通过HTTP API删除Doc
大数据·后端·云计算
Light604 小时前
星火链智:领码SPARK融合平台与湖北数据知识产权综合服务平台全栈对接技术白皮书
大数据·零信任安全·领码spark·数据知识产权·ipaas集成·ai数据治理
beijingliushao4 小时前
100-Spark Local模式部署
大数据·python·ajax·spark