【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>"
      }
    }
  }
}
相关推荐
Francek Chen7 分钟前
【大数据存储与管理】分布式数据库HBase:03 HBase数据模型
大数据·数据库·hadoop·分布式·hdfs·hbase
小程故事多_808 小时前
Vibe Coding的致命隐患,你必须知道的技术债务和扩展性危机
大数据·人工智能·aigc
wefly20178 小时前
开发者效率神器!jsontop.cn一站式工具集,覆盖开发全流程高频需求
前端·后端·python·django·flask·前端开发工具·后端开发工具
毕设源码-邱学长10 小时前
【开题答辩全过程】以 基于大数据技术的音乐推荐系统设计与实现为例,包含答辩的问题和答案
大数据
旺仔Sec11 小时前
2026年广东省职业院校技能大赛中职组“大数据应用与服务“赛项任务书(三)
大数据·hadoop
曾阿伦11 小时前
Elasticsearch 自定义分词匹配与同义词处理实战详解
大数据·elasticsearch·搜索引擎
天远云服11 小时前
天远企业司法认证API对接实战:PHP构建B2B供应链合规防火墙
大数据·开发语言·后端·node.js·php
赵谨言11 小时前
基于YOLOv5的植物目标检测研究
大数据·开发语言·经验分享·python
Hello.Reader12 小时前
Flink 应用升级与版本迁移Savepoint、状态兼容、跨版本恢复一次讲透
大数据·chrome·flink