java代码实现搜索elasticsearch索引数据

1、关于获取客户端以及增删改操作请看上一篇文章,文章中有详细的讲解

2、本篇文章讲述关于elasticsearch搜索匹配方式,主要有 match、match_phrase、term、regexp、wildcard、range和分页以及排序的方法

  (1)、分页查询数据,对结果进行排序完整格式为

1
2
3
4
5
6
{
    "from" :0, "size" :20,
    "query": {
          "match_all":{}
    },"sort": [{ "排序字段": { "order": "desc" }}]
}

  (2)、各种查询匹配格式(重要部分)

  match:分词匹配   "match": { "epNo" : "我是人" }  //匹配epNo包含 '我'   ‘是’   ‘人’   的数据,会将一个整的语句拆成一个字一个字的

  match_phrase:不分词匹配      "match_phrase": { "epNo" : "123456" }  //匹配epNo包含123456的数据

  term:完全匹配     "term": { "epNo" : "123456" }  //匹配epNo等于123456的数据

  regexp:正则匹配     "regexp": { "epNo" : "*123456*" }  //匹配epNo包含123456的数据

  wildcard:表达式匹配    "wildcard": { "epNo" : "*123456*" }  //匹配epNo包含123456的数据

  range:区间范围匹配    "range": { "goodsPrice": { "gte":20,"lte":50 } }  //匹配价钱在20~40中间的数据

  (3)、should的使用

  为了保证should中的条件至少有一个存在,语法如下

  "must": [
    {
      "bool": {
          "should": [
          { "match_phrase": { "goodsSubtitle": { "query" : "游戏", "boost" : 5 }}},
          { "match_phrase": { "goodsName": { "query" : "游戏", "boost" : 5 }}}
          ]
        }
    }
  ]

 

posted @   lazy_cxy  阅读(974)  评论(0编辑  收藏  举报
编辑推荐:
· 后端思维之高并发处理方案
· 理解Rust引用及其生命周期标识(下)
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
阅读排行:
· 后端思维之高并发处理方案
· 千万级大表的优化技巧
· 在 VS Code 中,一键安装 MCP Server!
· 想让你多爱自己一些的开源计时器
· 10年+ .NET Coder 心语 ── 继承的思维:从思维模式到架构设计的深度解析
点击右上角即可分享
微信分享提示