2013-08-28 19:24:34 -04:00
|
|
|
[[query-dsl-span-not-query]]
|
2019-07-18 10:18:11 -04:00
|
|
|
=== Span not query
|
|
|
|
++++
|
|
|
|
<titleabbrev>Span not</titleabbrev>
|
|
|
|
++++
|
2013-08-28 19:24:34 -04:00
|
|
|
|
2017-10-30 06:29:40 -04:00
|
|
|
Removes matches which overlap with another span query or which are
|
|
|
|
within x tokens before (controlled by the parameter `pre`) or y tokens
|
2018-03-19 13:22:40 -04:00
|
|
|
after (controlled by the parameter `post`) another SpanQuery. The span not
|
2013-08-28 19:24:34 -04:00
|
|
|
query maps to Lucene `SpanNotQuery`. Here is an example:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2016-05-24 05:58:43 -04:00
|
|
|
GET /_search
|
2013-08-28 19:24:34 -04:00
|
|
|
{
|
2016-05-24 05:58:43 -04:00
|
|
|
"query": {
|
|
|
|
"span_not" : {
|
|
|
|
"include" : {
|
|
|
|
"span_term" : { "field1" : "hoya" }
|
|
|
|
},
|
|
|
|
"exclude" : {
|
|
|
|
"span_near" : {
|
|
|
|
"clauses" : [
|
|
|
|
{ "span_term" : { "field1" : "la" } },
|
|
|
|
{ "span_term" : { "field1" : "hoya" } }
|
|
|
|
],
|
|
|
|
"slop" : 0,
|
|
|
|
"in_order" : true
|
|
|
|
}
|
2014-07-27 15:16:22 -04:00
|
|
|
}
|
2013-08-28 19:24:34 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
2016-05-24 05:58:43 -04:00
|
|
|
// CONSOLE
|
2013-08-28 19:24:34 -04:00
|
|
|
|
|
|
|
The `include` and `exclude` clauses can be any span type query. The
|
|
|
|
`include` clause is the span query whose matches are filtered, and the
|
|
|
|
`exclude` clause is the span query whose matches must not overlap those
|
|
|
|
returned.
|
2014-07-27 15:16:22 -04:00
|
|
|
|
2015-05-05 04:03:15 -04:00
|
|
|
In the above example all documents with the term hoya are filtered except the ones that have 'la' preceding them.
|
2014-11-24 07:16:36 -05:00
|
|
|
|
|
|
|
Other top level options:
|
|
|
|
|
|
|
|
[horizontal]
|
2017-10-30 06:29:40 -04:00
|
|
|
`pre`:: If set the amount of tokens before the include span can't have overlap with the exclude span. Defaults to 0.
|
|
|
|
`post`:: If set the amount of tokens after the include span can't have overlap with the exclude span. Defaults to 0.
|
2014-11-24 07:16:36 -05:00
|
|
|
`dist`:: If set the amount of tokens from within the include span can't have overlap with the exclude span. Equivalent
|
2015-05-05 02:27:52 -04:00
|
|
|
of setting both `pre` and `post`.
|