elasticsearch 基本操作CURD

  • Post author:
  • Post category:其他


一 、新建索引
1、格式
PUT /index/type/id     /索引名称/type类型/id
2、实例
PUT /ecommerce/product/1
{
   "name" : "gaolujie yagao",
   "desc" : "gaoxiao meibai",
   "price": 30,
   "producer" : "golujie producer",
   "tags" : ["meibai", "fangzhu"]
}


PUT /ecommerce/product/2
{
   "name" : "jiajieshi yagao",
   "desc" : "youxiao meibai",
   "price": 25,
   "producer" : "golujie producer",
   "tags" : ["fangzhu"]
}

PUT /ecommerce/product/3
{
   "name" : "zhonghua yagao",
   "desc" : "caoben meibai",
   "price": 40,
   "producer" : "zhonghua producer",
   "tags" : ["qingxin"]
}
二、查询
格式
1、GET index/type/_search    /索引名称/type类型/_search
GET  ecommerce/product/_search
2、GET index/type/1          /索引名称/type类型/id

三、更新
POST /index/type/1/_update     /索引名称/type类型/Id值/_update
POST /ecommerce/product/3/_update
{
   "doc":{     ##固定格式
   "name": "jiaqiangban zhonghua yaogao"
}
}

四、删除索引
DELETE  /index/type/1
DELETE /ecommerce/product/3



五、

商品的多挣搜索方式


:


1、query string search

2、query DSL

3、query filter

4、ful1-text search

5、phrase search

6、highlight search


1、

query string search

(搜索全部商品:   【生产环境中很少用】)

1.1 搜索全部商品

GET /ecommerce/product/_search

返回结果参数的解释:

1.2、  搜索商品名称中包含yaogao的商品,而且安装售价降序排序
GET  /ecommerce/product/_search?q=name:yagao&sort=price:desc

2、query DSL  [常用]
DSL: Domain Specified Language, 特定领域的语言
http request body: 请求体,可以用json的格式来构建查询语法,比较方便,可以构建各种复杂的语法,比query string search 肯定强大多了

2.1 查询所有商品
GET /ecommerce/product/_search
{
   "query": {
      "match_all": {}
   }
}
2.2  查询名称包含yagao的商品,同时按照价格降序排序
GET /ecommerce/product/_search
{
   "query": {
      "match": {
         "name": "yagao"
      }
   },
   "sort":[
      {"price": "desc"}
   ]
}

2.3  分页查询商品, 每页显示1条,显示第2页
GET /ecommerce/product/_search
{
"query": {
"match_all": {},
"from": 1,
"size": 1
}
}
2.4  指定要查询出来的商品的名称和价格就可以 ,只显示名称和价格
GET /ecommerce/product/_search
{
"query": {
"match_all": {}
},
"_source":["name", "price"]
}

3、query filter
3.1  搜索商品名称包含yagao, 而且售价大于25的商品[重要]
GET /ecommerce/product/_search
{
   "query" :{
      "bool": {
      "must": {
      "match":{
      "name":"yagao"
      }
      },
      "filter":{
            "range": {
               "price": {
                  "gt": 25
               }
            }
         }
      }
   }
}
4、full-text search(全文搜索)
GET  ecommerce/product/_search
{
   "query": {
      "match": {
         "producer": "yagao producer"
      }
   }
}
返回参数解释

5、phrase search   (短语搜索)
跟全文检索相对应,相反,全文检索会将输入的搜索串拆解开来,去倒排索引里面去一一匹配,只要能匹配上任意一个拆解后的单词,就可以作为结果返回
phrase search, 要求输入的搜索串,必须在指定的字段文本中,完全包含一模一样的,才可以算匹配,才能作为结果返回
GET  ecommerce/product/_search
{
   "query": {
      "match_phrase": {        #注意这个参数和上面的那个参数的区别
         "producer": "yagao producer"
      }
   }
}

6、heghlight search (高亮搜索结果显示  )
GET  ecommerce/product/_search
{
   "query": {
      "match":{
         "producer": "producer"
      }
   },
   "highlight": {
      "fields":{
         "producer": {}
      }
   }
}



版权声明:本文为weixin_46742102原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。