Elasticsearch 词项搜索

1)环境准备

启动Elasticsearch https://blog.csdn.net/qq_36918149/article/details/104221934
启动Kinbana https://blog.csdn.net/qq_36918149/article/details/104224625

2)基于term查询

定义&描述:
在这里插入图片描述
示例一:
写入数据

POST /products/_bulk
{ "index": { "_id": 1 }}
{ "productID" : "XHDK-A-1293-#fJ3","desc":"iPhone" }
{ "index": { "_id": 2 }}
{ "productID" : "KDKE-B-9947-#kL5","desc":"iPad" }
{ "index": { "_id": 3 }}
{ "productID" : "JODL-X-1937-#pV7","desc":"MBP" }

term查询

POST /products/_search
{
 "query": {
   "term": {
     "desc": {
      // 通过iPhone无法搜索到结果
      // 原因:因为desc被分词了(默认分词器还会转小写)。如果要做精确匹配,需要要看keyword类型的字段。
       "value": "iPhone"
       //"value":"iphone"
     }
   }
 }
}
POST /products/_search
{
  "query": {
    "term": {
      "productID": {
        "value": "XHDK-A-1293-#fJ3"
      }
    }
  }
}
 //未查询到结果,原因:因为productID被分词了(默认分词器还会转小写)。如果要做精确匹配,需要要看keyword类型的字段。
POST /products/_search
{
  "explain": true,
  "query": {
    "constant_score": {
      "filter": {
        "term": {
          "productID.keyword": "XHDK-A-1293-#fJ3"
        }
      }
    }
  }
}
//该查询有结果返回,
//原因:是text会做分词。keyword不做分词。term查询是把你输入的“内容”不做任何处理,去和text和keyword中的内容比较。在text中,product-Id被分成词了,全部转为小写了。
//"keyword" 属于用了es多字段属性的特性

3)总结

用term查询的时候一定要注意,有大小写字符串查询的时候, 先转换为小写再查询,否则查询不到真正结果。
用keyword field 查询的时候, 有大写字母也可以查询 ,表示准精确匹配。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值