Skip to main content
Version: User Guides (BYOC)

Load & Release

Loading a collection is the prerequisite to conducting similarity searches and queries in collections. This page focuses on the procedures for loading and releasing a collection.

Load Collection

When you load a collection, Zilliz Cloud loads the index files and the raw data of all fields into memory for rapid response to searches and queries. Entities inserted after a collection load are automatically indexed and loaded.

The following code snippets demonstrate how to load a collection.

from pymilvus import MilvusClient

client = MilvusClient(
uri="YOUR_CLUSTER_ENDPOINT",
token="YOUR_CLUSTER_TOKEN"
)

# 7. Load the collection
client.load_collection(
collection_name="customized_setup_1"
)

res = client.get_load_state(
collection_name="customized_setup_1"
)

print(res)

# Output
#
# {
# "state": "<LoadState: Loaded>"
# }

Load Specific Fields

Zilliz Cloud can load only the fields involved in searches and queries, reducing memory usage and improving search performance.

The following code snippet assumes that you have created a collection named customized_setup_2, and there are two fields named my_id and my_vector in the collection.

client.load_collection(
collection_name="customized_setup_1",
load_fields=["my_id", "my_vector"] # Load only the specified fields
skip_load_dynamic_field=True # Skip loading the dynamic field
)

res = client.get_load_state(
collection_name="customized_setup_1"
)

print(res)

# Output
#
# {
# "state": "<LoadState: Loaded>"
# }

If you choose to load specific fields, it is worth noting that only the fields included in load_fields can be used as filters and output fields in searches and queries. You should always include the names of the primary field and at least one vector field in load_fields.

You can also use skip_load_dynamic_field to determine whether to load the dynamic field. The dynamic field is a reserved JSON field named $meta and saves all non-schema-defined fields and their values in key-value pairs. When loading the dynamic field, all keys in the fields are loaded and available for filtering and output. If all keys in the dynamic field are not involved in metadata filtering and output, set skip_load_dynamic_field to True.

To load more fields after the collection load, you need to release the collection first to avoid possible errors prompted because of index changes.

Release Collection

Searches and queries are memory-intensive operations. To save the cost, you are advised to release the collections that are currently not in use.

The following code snippet demonstrates how to release a collection.

# 8. Release the collection
client.release_collection(
collection_name="custom_quick_setup"
)

res = client.get_load_state(
collection_name="custom_quick_setup"
)

print(res)

# Output
#
# {
# "state": "<LoadState: NotLoad>"
# }