【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>"
      }
    }
  }
}
相关推荐
集和诚JHCTECH2 分钟前
BRAV-7120加持,让有毒有害气体无处遁形
大数据·人工智能·嵌入式硬件
互联网志1 小时前
加速高校科技成果转化 赋能实体经济高质量发展
大数据·人工智能·物联网
李可以量化1 小时前
DeepSeek 量化交易实战:用标准化提示词模板实现 AI 辅助交易决策
大数据·数据库·人工智能
学掌门2 小时前
数据分析师职业规划——数据分析师的职业焦虑与未来发展
大数据·信息可视化
亚马逊云开发者2 小时前
EMR Core 节点部署 Flink Client 实战:Bootstrap Action 一次打包多次复用,解决调度系统提交任务的痛点
大数据·flink·bootstrap
盘古信息IMS2 小时前
九宸纳百川,数智启新程|盘古信息与合肥昊邦科技合资成立合肥九宸智能,共筑智造新生态
大数据·人工智能
Irene19912 小时前
大数据开发语境下,SQL 模式名,映射关系 - - 概念理解
大数据·数据库·sql
小熊美家熊猫系统3 小时前
社区家政与平台家政:两种创业模式的深度对比分析
大数据·家政行业·社区家政·平台家政·家政管理软件
互联网志3 小时前
打通转化通道 赋能产业发展——高校科技成果转化的现状与破局
大数据·人工智能·物联网
绿虫光伏运维3 小时前
一文理清光伏运维的内容、常见问题与重要措施
大数据·运维·光伏业务