recherche

Maison  >  Questions et réponses  >  le corps du texte

elasticsearch - Elastisearch怎么求查询结果的交集,如MYSQL的interset

1.查询20151216-17所有的名字

{
"from": 0,
"size": 200,
"query": {
    "bool": {
        "must": {
            "range": {
                "DATE": {
                    "from": 20151216,
                    "to": 2015121617,
                    "include_lower": true,
                    "include_upper": true
                }
            }
        }
    }
},
"_source": {
    "includes": [
        "NAME"
    ],
    "excludes": []
}

2.查询20151217-18所有的名字

{
"from": 0,
"size": 200,
"query": {
    "bool": {
        "must": {
            "range": {
                "DATE": {
                    "from": 20151216,
                    "to": 2015121617,
                    "include_lower": true,
                    "include_upper": true
                }
            }
        }
    }
},
"_source": {
    "includes": [
        "NAME"
    ],
    "excludes": []
}

如果在mysql中可用如下的语句求得这两天name的交集

SELECT NAME FROM Table1 where DATE between 20151216 and 20151217 interset SELECT NAME FROM Table1 where DATE between 20151217 and 20151218    

Elastisearch中怎么做呢?

高洛峰高洛峰2839 Il y a quelques jours1562

répondre à tous(2)je répondrai

  • ringa_lee

    ringa_lee2017-04-17 16:00:47

    SELECT NAME FROM Table1 where DATE between 20151216 and 20151217 interset SELECT NAME FROM Table1 where DATE between 20151217 and 20151218

    我把楼主的SQL修改一下不知是否满足楼主的需求,如果满足我想下面的elasticsearch应该也是可以使用的

    SELECT NAME FROM Table1 where (DATE between 20151217 and 20151218) OR (DATE between 20151216 and 20151217)
    GROUP BY NAME

    REQUEST:

    {
        "query": {
            "bool": {
                "should":[
                    {
                        "range": {
                            "createdTime": {
                                "from": 1477984000,
                                "to": 1477984695
                            }
                        }
                    },
                    {
                        "range": {
                            "createdTime": {
                                "from": 1477984000,
                                "to": 1477984835
                            }
                        }
                    }
                ]
            }
        },
        "size": 0,
        "aggs": {
            "my_price": {
                "terms": {
                    "field": "price"
                }
            }
        }
    }

    RESPONSE:

    {
      "took": 3,
      "timed_out": false,
      "_shards": {
        "total": 5,
        "successful": 5,
        "failed": 0
      },
      "hits": {
        "total": 542,
        "max_score": 0,
        "hits": []
      },
      "aggregations": {
        "my_price": {
          "doc_count_error_upper_bound": 8,
          "sum_other_doc_count": 377,
          "buckets": [
            {
              "key": 148,
              "doc_count": 24
            },
            {
              "key": 98,
              "doc_count": 23
            },
            {
              "key": 128,
              "doc_count": 20
            },
            {
              "key": 160,
              "doc_count": 20
            },
            {
              "key": 108,
              "doc_count": 18
            },
            {
              "key": 105,
              "doc_count": 14
            },
            {
              "key": 100,
              "doc_count": 13
            },
            {
              "key": 118,
              "doc_count": 12
            },
            {
              "key": 88,
              "doc_count": 11
            },
            {
              "key": 81,
              "doc_count": 10
            }
          ]
        }
      }
    }

    我这里是使用的数据创建时间,查询其价格,因为我的数据中只有价格是重复的,就采用这个做一个测试。
    使用 aggs 对数据进行分组,"size":0是禁止返回hits数据,这样直接读取aggregations.my_price.buckets属性就是你需要的数据集。

    répondre
    0
  • 天蓬老师

    天蓬老师2017-04-17 16:00:47

    印象中没有这个语法,对于nosql,查出来的都是json风格数据,用程序做下也很简单高效。

    répondre
    0
  • Annulerrépondre