我们在使用 Elasticsearch 的 DSL 进行搜索时,还可以指定多个查询条件,对结果进行过滤,指定多个查询条件,我们可以通过 query 里面的 bool 来指定。
GET /indexname/_search { "query" : { "bool" : { "must" : { }, "filter" : { } } } }
参数 | 描述 |
---|---|
indexname | 需要搜索的索引名 |
must | 必须满足的条件 |
filter | 过滤条件 |
我们在 Kibana 的控制台上,输入以下代码,新建一个文档:
PUT /haicodernet/_doc/1 { "name" : "javascript", "desc" : "javascript module", "categorys" : 5, "author" : "jobs steven", "tags": [ "javascript", "vue" ], "index":"www.haicoder.net" }
输入完成后,我们点击运行按钮,输出了最终的运行结果,如下图所示:
我们看到,此时我们创建文档成功了,现在,我们再次输入以下代码,再次创建一条文档:
PUT /haicodernet/_doc/2 { "name" : "server", "desc" : "server module", "categorys" : 10, "author" : "cainiao pei", "tags": [ "server", "python" ], "index":"www.haicoder.net" }
输入完成后,我们点击运行按钮,输出了最终的运行结果,如下图所示:
同样,我们再次创建一条记录,使用如下命令:
PUT /haicodernet/_doc/3 { "name" : "tools", "desc" : "tools module", "categorys" : 15, "author" : "cainiao pei", "tags": [ "tools", "vim" ], "index":"www.haicoder.net" }
即,我们再次成功创建了一个文档,现在,我们使用 DSL 指定多个条件,进行文档的搜索,具体命令如下:
GET /haicodernet/_search { "query" : { "bool" : { "must" : { "match" : { "author" : "cainiao pei" } }, "filter" : { "range" : { "categorys" : { "gt" : 10 } } } } } }
输入完成后,我们点击运行按钮,输出了最终的运行结果,如下图所示:
我们看到,我们使用 DSL 查询了 author 字段以及使用了 filter 过滤了 categorys 字段。
我们在使用 Elasticsearch 的 DSL 进行搜索时,还可以指定多个查询条件,对结果进行过滤,指定多个查询条件,我们可以通过 query 里面的 bool 来指定。