ES的bool查询

must:与关系,相当于关系型数据库中的 and。

should:或关系,相当于关系型数据库中的 or。

must_not:非关系,相当于关系型数据库中的 not。

filter:过滤条件。

range:条件筛选范围。

gt:大于,相当于关系型数据库中的 >。

gte:大于等于,相当于关系型数据库中的 >=。

lt:小于,相当于关系型数据库中的 <。

lte:小于等于,相当于关系型数据库中的 <=


#创建索引
PUT /items



#初始化数据
POST /items/_bulk
{ "index": { "_id": 1 }}
{ "price" : 40, "itemID" : "ID1001" }
{ "index": { "_id": 2 }}
{ "price" : 50, "itemID" : "ID1002" }
{ "index": { "_id": 3 }}
{ "price" : 25, "itemID" : "ID1004" }
{ "index": { "_id": 4 }}
{ "price" : 30, "itemID" : "ID1004" }
{ "index": { "_id": 5 }}
{ "price" : null, "itemID" : "ID1005" }

GET items/_mapping



GET items/_search
{
  "query": {
    "match_all": {}
  }
}

#查询价格等于25,并且ItemID是ID1004
GET items/_search
{
    "query": {
        "bool": {
            "must": [
                {
                    "term": {
                        "price": "25"
                    }
                },
                {
                    "term": {
                        "itemID": "id1004"
                    }
                }
            ]
        }
    }
}

# 过滤查询价格等于40
GET items/_search
{
  "query": {
    "bool": {
      "filter": [
        {"term": {
          "price": "40"
        }}
      ]
    }
  }
}

#过滤价格是30至50
GET items/_search
{
  "query": {
    "bool": {
      "filter": [
        {"range": {
          "price": {
            "gte": 30,
            "lte": 50
          }
        }}
      ]
    }
  }
}


# 查询价格是25或itemID是ID1004,同时价格不为30
GET items/_search
{
    "query": {
        "bool": {
            "should": [
                {
                    "term": {
                        "price": 25
                    }
                },
                {
                    "term": {
                        "itemID": "id1004"
                    }
                }
            ],
            "must_not": [
              {"term": {
                        "price": 30
                    }}
            ]
        }
    }
}


DELETE items


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值