Span not query

Span not query

Removes matches which overlap with another span query or which are within x tokens before (controlled by the parameter pre) or y tokens after (controlled by the parameter post) another SpanQuery. Here is an example:

  1. resp = client.search(
  2. query={
  3. "span_not": {
  4. "include": {
  5. "span_term": {
  6. "field1": "hoya"
  7. }
  8. },
  9. "exclude": {
  10. "span_near": {
  11. "clauses": [
  12. {
  13. "span_term": {
  14. "field1": "la"
  15. }
  16. },
  17. {
  18. "span_term": {
  19. "field1": "hoya"
  20. }
  21. }
  22. ],
  23. "slop": 0,
  24. "in_order": True
  25. }
  26. }
  27. }
  28. },
  29. )
  30. print(resp)
  1. response = client.search(
  2. body: {
  3. query: {
  4. span_not: {
  5. include: {
  6. span_term: {
  7. "field1": 'hoya'
  8. }
  9. },
  10. exclude: {
  11. span_near: {
  12. clauses: [
  13. {
  14. span_term: {
  15. "field1": 'la'
  16. }
  17. },
  18. {
  19. span_term: {
  20. "field1": 'hoya'
  21. }
  22. }
  23. ],
  24. slop: 0,
  25. in_order: true
  26. }
  27. }
  28. }
  29. }
  30. }
  31. )
  32. puts response
  1. const response = await client.search({
  2. query: {
  3. span_not: {
  4. include: {
  5. span_term: {
  6. field1: "hoya",
  7. },
  8. },
  9. exclude: {
  10. span_near: {
  11. clauses: [
  12. {
  13. span_term: {
  14. field1: "la",
  15. },
  16. },
  17. {
  18. span_term: {
  19. field1: "hoya",
  20. },
  21. },
  22. ],
  23. slop: 0,
  24. in_order: true,
  25. },
  26. },
  27. },
  28. },
  29. });
  30. console.log(response);
  1. GET /_search
  2. {
  3. "query": {
  4. "span_not": {
  5. "include": {
  6. "span_term": { "field1": "hoya" }
  7. },
  8. "exclude": {
  9. "span_near": {
  10. "clauses": [
  11. { "span_term": { "field1": "la" } },
  12. { "span_term": { "field1": "hoya" } }
  13. ],
  14. "slop": 0,
  15. "in_order": true
  16. }
  17. }
  18. }
  19. }
  20. }

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.

In the above example all documents with the term hoya are filtered except the ones that have la preceding them.

Other top level options:

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.

dist

If set the amount of tokens from within the include span can’t have overlap with the exclude span. Equivalent of setting both pre and post.