Skip to content

Commit

Permalink
Apply suggestions from code review
Browse files Browse the repository at this point in the history
Signed-off-by: kolchfa-aws <[email protected]>
  • Loading branch information
kolchfa-aws authored Jan 9, 2025
1 parent f7551b0 commit 02ade85
Showing 1 changed file with 0 additions and 19 deletions.
19 changes: 0 additions & 19 deletions _query-dsl/term/terms.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ GET shakespeare/_search
}
}
```

{% include copy-curl.html %}

A document is returned if it matches any of the terms in the array.
Expand Down Expand Up @@ -64,7 +63,6 @@ PUT students
}
}
```

{% include copy-curl.html %}

Next, index three documents that correspond to students:
Expand All @@ -76,7 +74,6 @@ PUT students/_doc/1
"student_id" : "111"
}
```

{% include copy-curl.html %}

```json
Expand All @@ -86,7 +83,6 @@ PUT students/_doc/2
"student_id" : "222"
}
```

{% include copy-curl.html %}

```json
Expand All @@ -96,7 +92,6 @@ PUT students/_doc/3
"student_id" : "333"
}
```

{% include copy-curl.html %}

Create a separate index that contains class information, including the class name and an array of student IDs corresponding to the students enrolled in the class:
Expand All @@ -108,7 +103,6 @@ PUT classes/_doc/101
"enrolled" : ["111" , "222"]
}
```

{% include copy-curl.html %}

To search for students enrolled in the `CS101` class, specify the document ID of the document that corresponds to the class, the index of that document, and the path of the field in which the terms are located:
Expand All @@ -127,7 +121,6 @@ GET students/_search
}
}
```

{% include copy-curl.html %}

The response contains the documents in the `students` index for every student whose ID matches one of the values in the `enrolled` array:
Expand Down Expand Up @@ -185,7 +178,6 @@ PUT classes/_doc/102
}
}
```

{% include copy-curl.html %}

To search for students enrolled in `CS102`, use the dot path notation to specify the full path to the field in the `path` parameter:
Expand All @@ -204,7 +196,6 @@ GET students/_search
}
}
```

{% include copy-curl.html %}

The response contains the matching documents:
Expand Down Expand Up @@ -262,7 +253,6 @@ Parameter | Data type | Description
`boost` | Floating-point | A floating-point value that specifies the weight of this field toward the relevance score. Values above 1.0 increase the field’s relevance. Values between 0.0 and 1.0 decrease the field’s relevance. Default is 1.0.

## Bitmap filtering

**Introduced 2.17**
{: .label .label-purple }

Expand All @@ -282,7 +272,6 @@ PUT /products
}
}
```

{% include copy-curl.html %}

Next, index three documents that correspond to products:
Expand All @@ -294,7 +283,6 @@ PUT /products/_doc/1
"product_id" : "111"
}
```

{% include copy-curl.html %}

```json
Expand All @@ -304,7 +292,6 @@ PUT /products/_doc/2
"product_id" : "222"
}
```

{% include copy-curl.html %}

```json
Expand All @@ -314,7 +301,6 @@ PUT /products/_doc/3
"product_id" : "333"
}
```

{% include copy-curl.html %}

To store customer bitmap filters, you'll create a `customer_filter` [binary field](https://opensearch.org/docs/latest/field-types/supported-field-types/binary/) in the `customers` index. Specify `store` as `true` to store the field:
Expand All @@ -332,7 +318,6 @@ PUT /customers
}
}
```

{% include copy-curl.html %}

For each customer, you need to generate a bitmap that represents the product IDs of the products the customer owns. This bitmap effectively encodes the filter criteria for that customer. In this example, you'll create a `terms` filter for a customer whose ID is `customer123` and who owns products `111`, `222`, and `333`.
Expand All @@ -353,7 +338,6 @@ encoded_bm_str = encoded.decode('utf-8')
# Print the encoded bitmap
print(f"Encoded Bitmap: {encoded_bm_str}")
```

{% include copy.html %}

Next, index the customer filter into the `customers` index. The document ID for the filter is the same as the ID for the corresponding customer (in this example, `customer123`). The `customer_filter` field contains the bitmap you generated for this customer:
Expand All @@ -364,7 +348,6 @@ POST customers/_doc/customer123
"customer_filter": "OjAAAAEAAAAAAAIAEAAAAG8A3gBNAQ=="
}
```

{% include copy-curl.html %}

Now you can run a `terms` query on the `products` index to look up a specific customer in the `customers` index. Because you're looking up a stored field instead of `_source`, set `store` to `true`. In the `value_type` field, specify the data type of the `terms` input as `bitmap`:
Expand All @@ -385,7 +368,6 @@ POST /products/_search
}
}
```

{% include copy-curl.html %}

You can also directly pass the bitmap to the `terms` query. In this example, the `product_id` field contains the customer filter bitmap for the customer whose ID is `customer123`:
Expand All @@ -401,5 +383,4 @@ POST /products/_search
}
}
```

{% include copy-curl.html %}

0 comments on commit 02ade85

Please sign in to comment.