Elasticsearch查询之Match

学习几天的elasticsearch总结下match匹配以方便温习。

首先我创建了一个index:mytest,type:usertest,并插入了5条数据。

ps:用的sense浏览器插件(如何安装可以百度)

pretty:美化查询结果。

_search:搜索关键字
query: 及表示查询
match: 匹配

一、简单的全查找:

式例:

POST /mytest/usertest/_search?pretty
{
     "query":{
            "match_all": {}
        }

}

mytest:index名称(对应关系数据库名称)
usertest:_type名称(对应关系数据库表名)

查询结果图:

通过hits 内total:5可以看出5条记录都查询出来了 
另外一种简单的写法示例:
POST /mytest/user/_search
推荐用第一种json体的方法,扩展性和灵活性更加多样化。但是简单的查询第一种就可以完成,视情况而定吧。
这个美化查询结果,看了半天觉得没啥变化,注:_source参数不会被美化。

二、查询单条数据
1:POST /mytest/usertest/_search?q=name:xiaofang

2:json体:
POST /mytest/usertest/_search?pretty
{
   "query":{
"match":{
      "name":"xiaofang"
   }
        }

}


简单说明:username:为字段名称和关系数据库字段一个意思。
      按照等分高低排列
笔者在使用java api进行操作时没有用QueryBuilders.matchPhraseQuery方法时返回结果包含“xiao”单词的文档(测试时使用的中文检索)
三、简单的条件查询:

查询usertest中年龄在20周岁以下的人员
   1: POST /mytest/usertest/_search
{   
    "query": {
        "match_all": {}
    },
            "filter":{
                "range": {
                    "userage": {
                      "from": 18,
                      "to": 20
                    }
                }
            }
        
}


查询年龄小于20周岁以下的人员
    2: POST /mytest/usertest/_search
{
    "query": {
        "match_all": {}
    },
            "filter":{
                "range": {
                   "userage": {
                      "lt" : "20"
                    }
                }
            }
      

}

 

我们可以通过查询结果看出两者之间的差别
这两个示例用到了“filter”,“range”这两个关键词。
filter:过滤器。用于过滤我们的查询结果,让查询结果更加精确化。
range:区间。(以上是range的简单的两种写法)
"lt" 转移字符 “小于”的意思。
"gt" :“大于”的意思。


四、match_phrase关键字查询:
match_phrase:短语搜索。
对比示例:
未使用match_phrase查询的代码及结果:


POST /mytest/usertest/_search
{
    "query": {
        "match": {
            "about": "listen music"
        }
    }
}




使用match_phrase查询的代码及结果:
POST /mytest/usertest/_search
{
    "query": {
        "match_phrase": {
            "about": "listen music"
        }
    }

}

match_phrase查询就不多说啦,一看就明白。


五、match_phrase_prefix查询
match_phrase_prefix:匹配短语前缀查询。
上两个示例就一目了然啦:
POST /mytest/usertest/_search
{   "query": { 
        "match_phrase": {
              "about": "love lis"
            }
        
    }    
}




POST /mytest/usertest/_search
{   "query": { 
        "match_phrase_prefix": {
              "about": "love lis"
            }
        
    }    
}




关于match匹配搜索就写到这儿吧。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Elasticsearchmatch查询可以用于多条件查询,可以通过使用bool查询来实现。bool查询可以将多个查询条件组合在一起,包括must、should、must_not和filter。 例如,我们想要查询title字段包含“elasticsearch”和content字段包含“java”的文档,可以使用以下查询: ``` { "query": { "bool": { "must": [ { "match": { "title": "elasticsearch" } }, { "match": { "content": "java" } } ] } } } ``` 这个查询使用了bool查询,将两个match查询条件组合在一起,使用must关键字表示这两个条件都必须满足。如果我们想要查询title字段包含“elasticsearch”或content字段包含“java”的文档,可以使用should关键字: ``` { "query": { "bool": { "should": [ { "match": { "title": "elasticsearch" } }, { "match": { "content": "java" } } ] } } } ``` 这个查询使用了should关键字,表示只要满足其中一个条件即可。如果我们想要查询title字段包含“elasticsearch”但是content字段不包含“java”的文档,可以使用must和must_not关键字: ``` { "query": { "bool": { "must": [ { "match": { "title": "elasticsearch" } } ], "must_not": [ { "match": { "content": "java" } } ] } } } ``` 这个查询使用了must和must_not关键字,表示title字段必须包含“elasticsearch”,但是content字段不能包含“java”。如果我们想要查询title字段包含“elasticsearch”并且content字段包含“java”,但是只返回score大于等于0.5的文档,可以使用filter关键字: ``` { "query": { "bool": { "must": [ { "match": { "title": "elasticsearch" } }, { "match": { "content": "java" } } ], "filter": { "range": { "_score": { "gte": 0.5 } } } } } } ``` 这个查询使用了filter关键字,表示只返回score大于等于0.5的文档。注意,filter查询不会影响score的计算,因此可以提高查询效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值