es不建议模糊搜索_elasticsearch match模糊查询

elasticsearch 中term与match区别

elasticsearch 中term与match区别

term是精确查询

match是模糊查询

term查询

term是代表完全匹配,也就是精确查询,搜索前不会再对搜索词进行分词,所以我们的搜索词必须是文档分词集合中的一个。比如说我们要找标题为北京奥运的所有文档

$curl -XGET http://localhost:9200/index/doc/_search?pretty -d

'{

"query":{

"term":{

"title":"北京奥运"

}

}

}'

将会得到如下结果

{

"took": 1,

"timed_out": false,

"_shards": {

"total": 5,

"successful": 5,

"failed": 0

},

"hits": {

"total": 1,

"max_score": 0.92055845,

"hits": [

{

"_index": "index",

"_type": "doc",

"_id": "3",

"_score": 0.92055845,

"_source": {

"content": "同一个世界同一个梦想",

"title": "北京奥运",

"tags": [

"和平"

]

}

}

]

}

}

match类查询

match查询会先对搜索词进行分词,分词完毕后再逐个对分词结果进行匹配,因此相比于term的精确搜索,match是分词匹配搜索,match搜索还有两个相似功能的变种,一个是match_phrase,一个是multi_match,接下来详细介绍一下

match

前面提到match搜索会先对搜索词进行分词,对于最基本的match搜索来说,只要搜索词的分词集合中的一个或多个存在于文档中即可,例如,当我们搜索中国杭州,搜索词会先分词为中国和杭州,只要文档中包含搜索和杭州任意一个词,都会被搜索到

$curl -XGET http://localhost:9200/index/doc/_search?pretty -d

'{

"query": {

"match": {

"content": "中国杭州"

}

}

}'

文档3正文中有杭州,文档2中有中国,因此搜索结果有两个,文档3中杭州出现两次,所以排在前面,结果如下:

{

"took" : 1,

"timed_out" : false,

"_shards" : {

"total" : 5,

"successful" : 5,

"failed" : 0

},

"hits" : {

"total" : 2,

"max_score" : 0.99999994,

"hits" : [ {

"_index" : "index",

"_type" : "doc",

"_id" : "4",

"_score" : 0.99999994,

"_source" : {

"content" : "杭州是一个美丽的城市,欢迎来到杭州",

"title" : "宣传",

"tags" : [ "旅游", "城市" ]

}

}, {

"_index" : "index",

"_type" : "doc",

"_id" : "2",

"_score" : 0.8838835,

"_source" : {

"content" : "中国是世界上人口最多的国家",

"title" : "中国",

"tags" : [ "中国", "人口" ]

}

} ]

}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值