【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>"
      }
    }
  }
}
相关推荐
Forrit32 分钟前
Agent长期运行(Long-Running Tasks)实现方案与核心挑战
大数据·人工智能·深度学习
2601_955363151 小时前
技术赋能B端拓客:号码核验的行业困局与破局路径氪迹科技法人股东筛选系统,阶梯式价格
大数据·人工智能
财经资讯数据_灵砚智能2 小时前
全球财经资讯日报(夜间-次晨)2026年3月28日
大数据·人工智能·python·语言模型·ai编程
@insist1232 小时前
数据库系统工程师-云计算与大数据核心知识
大数据·数据库·云计算·软考·数据库系统工程师·软件水平考试
scan7243 小时前
小龙虾模拟人的性格,需要带上历史信息作为上下文
大数据
creaDelight3 小时前
基于 Django 5.x 的全功能博客系统 DjangoBlog 深度解析
后端·python·django
Elasticsearch3 小时前
Elasticsearch:如何在 Elastic AI Builder 里使用 DSL 来查询 Elasticsearch
elasticsearch
Yiyaoshujuku4 小时前
医院API接口,从医院真实世界数据HIS、LJS、EMR、PACS系统到医院药品流向数据....
大数据·前端·人工智能
STLearner4 小时前
AI论文速读 | 元认知监控赋能深度搜索:认知神经科学启发的分层优化框架
大数据·论文阅读·人工智能·python·深度学习·学习·机器学习
不一样的故事1264 小时前
抓重点、留弹性、重节奏
大数据·网络·人工智能·安全