Skip to main content
Version: User Guides (BYOC)

Basic Operators

Zilliz Cloud provides a rich set of basic operators to help you filter and query data efficiently. These operators allow you to refine your search conditions based on scalar fields, numeric calculations, logical conditions, and more. Understanding how to use these operators is crucial for building precise queries and maximizing the efficiency of your searches.

Comparison operators

Comparison operators are used to filter data based on equality, inequality, or size. They are applicable to numeric and text fields.

Supported Comparison Operators:

  • == (Equal to)

  • != (Not equal to)

  • > (Greater than)

  • < (Less than)

  • >= (Greater than or equal to)

  • <= (Less than or equal to)

Example 1: Filtering with Equal To (==)

Assume you have a field named status and you want to find all entities where status is "active". You can use the equality operator ==:

filter = 'status == "active"'

Example 2: Filtering with Not Equal To (!=)

To find entities where status is not "inactive":

filter = 'status != "inactive"'

Example 3: Filtering with Greater Than (>)

If you want to find all entities with an age greater than 30:

filter = 'age > 30'

Example 4: Filtering with Less Than

To find entities where price is less than 100:

filter = 'price < 100'

Example 5: Filtering with Greater Than or Equal To (>=)

If you want to find all entities with rating greater than or equal to 4:

filter = 'rating >= 4'

Example 6: Filtering with Less Than or Equal To

To find entities with discount less than or equal to 10%:

filter = 'discount <= 10'

Range operators

Range operators help filter data based on specific sets or ranges of values.

Supported Range Operators:

  • IN: Used to match values within a specific set or range.

  • LIKE: Used to match a pattern (mostly for text fields).

Example 1: Using IN to Match Multiple Values

If you want to find all entities where the color is either "red", "green", or "blue":

filter = 'color in ["red", "green", "blue"]'

This is useful when you want to check for membership in a list of values.

Example 2: Using LIKE for Pattern Matching

The LIKE operator is used for pattern matching in string fields. It can match substrings in different positions within the text: as a prefix, infix, or suffix. The LIKE operator uses the % symbol as a wildcard, which can match any number of characters (including zero).

Prefix Match (Starts With)

To perform a prefix match, where the string starts with a given pattern, you can place the pattern at the beginning and use % to match any characters following it. For example, to find all products whose name starts with "Prod":

filter = 'name LIKE "Prod%"'

This will match any product whose name starts with "Prod", such as "Product A", "Product B", etc.

Suffix Match (Ends With)

For a suffix match, where the string ends with a given pattern, place the % symbol at the beginning of the pattern. For example, to find all products whose name ends with "XYZ":

filter = 'name LIKE "%XYZ"'

This will match any product whose name ends with "XYZ", such as "ProductXYZ", "SampleXYZ", etc.

Infix Match (Contains)

To perform an infix match, where the pattern can appear anywhere in the string, you can place the % symbol at both the beginning and the end of the pattern. For example, to find all products whose name contains the word "Pro":

filter = 'name LIKE "%Pro%"'

This will match any product whose name contains the substring "Pro", such as "Product", "ProLine", or "SuperPro".

Arithmetic Operators

Arithmetic operators allow you to create conditions based on calculations involving numeric fields.

Supported Arithmetic Operators:

  • + (Addition)

  • - (Subtraction)

  • * (Multiplication)

  • / (Division)

  • % (Modulus)

  • ** (Exponentiation)

Example 1: Using Addition (+)

To find entities where the total price is the sum of base_price and tax:

filter = 'total == base_price + tax'

Example 2: Using Subtraction (-)

To find entities where the difference between quantity and quantity_sold is greater than 50:

filter = 'quantity - quantity_sold > 50'

Example 3: Using Multiplication (*)

To find entities where the product of the price and quantity field values are greater than 1000:

filter = 'price * quantity > 1000'

Example 4: Using Division (/)

To find products where total_price divided by quantity is less than 50:

filter = 'total_price / quantity < 50'

Example 5: Using Modulus (%)

To find entities where the id is an even number (i.e., divisible by 2):

filter = 'id % 2 == 0'

Example 6: Using Exponentiation (**)

To find entities where price raised to the power of 2 is greater than 1000:

filter = 'price ** 2 > 1000'

Logical Operators

Logical operators are used to combine multiple conditions into a more complex filter expression. These include AND, OR, and NOT.

Supported Logical Operators:

  • AND: Combines multiple conditions that must all be true.

  • OR: Combines conditions where at least one must be true.

  • NOT: Negates a condition.

Example 1: Using AND to Combine Conditions

To find all products where price is greater than 100 and stock is greater than 50:

filter = 'price > 100 AND stock > 50'

Example 2: Using OR to Combine Conditions

To find all products where color is either "red" or "blue":

filter = 'color == "red" OR color == "blue"'

Example 3: Using NOT to Exclude a Condition

To find all products where color is not "green":

filter = 'NOT color == "green"'

Tips on Using Basic Operators with JSON and ARRAY Fields

While the basic operators in Zilliz Cloud clusters are versatile and can be applied to scalar fields, they can also be effectively used with the keys and indexes in the JSON and ARRAY fields.

For example, if you have a product field that contains multiple keys like price, model, and tags, always reference the key directly:

filter = 'product["price"] > 1000'

To find records where the first temperature in an array of recorded temperatures exceeds a certain value, use:

filter = 'history_temperatures[0] > 30'

Conclusion

Zilliz Cloud offers a range of basic operators that give you flexibility in filtering and querying your data. By combining comparison, range, arithmetic, and logical operators, you can create powerful filter expressions to narrow down your search results and retrieve the data you need efficiently.