Class MilvusEmbeddingStore
java.lang.Object
dev.langchain4j.store.embedding.milvus.MilvusEmbeddingStore
- All Implemented Interfaces:
EmbeddingStore<TextSegment>
Represents an Milvus index as an embedding store.
Supports both local and managed Milvus instances.
Supports storing
Supports both local and managed Milvus instances.
Supports storing
Metadata
and filtering by it using a Filter
(provided inside an EmbeddingSearchRequest
).-
Nested Class Summary
-
Constructor Summary
ConstructorDescriptionMilvusEmbeddingStore
(io.milvus.client.MilvusServiceClient milvusClient, String collectionName, Integer dimension, io.milvus.param.IndexType indexType, io.milvus.param.MetricType metricType, io.milvus.common.clientenum.ConsistencyLevelEnum consistencyLevel, Boolean retrieveEmbeddingsOnSearch, Boolean autoFlushOnInsert, String idFieldName, String textFieldName, String metadataFiledName, String vectorFiledName) MilvusEmbeddingStore
(String host, Integer port, String collectionName, Integer dimension, io.milvus.param.IndexType indexType, io.milvus.param.MetricType metricType, String uri, String token, String username, String password, io.milvus.common.clientenum.ConsistencyLevelEnum consistencyLevel, Boolean retrieveEmbeddingsOnSearch, Boolean autoFlushOnInsert, String databaseName, String idFieldName, String textFieldName, String metadataFiledName, String vectorFiledName) -
Method Summary
Modifier and TypeMethodDescriptionAdds a given embedding to the store.add
(Embedding embedding, TextSegment textSegment) Adds a given embedding and the corresponding content that has been embedded to the store.void
Adds a given embedding to the store.Adds multiple embeddings to the store.void
Adds multiple embeddings and their corresponding contents that have been embedded to the store.static MilvusEmbeddingStore.Builder
builder()
void
dropCollection
(String collectionName) void
Removes all embeddings from the store.void
Removes all embeddings that match the specifiedFilter
from the store.void
removeAll
(Collection<String> ids) Removes a single embedding from the store by ID.search
(EmbeddingSearchRequest embeddingSearchRequest) Searches for the most similar (closest in the embedding space)Embedding
s.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface dev.langchain4j.store.embedding.EmbeddingStore
addAll, findRelevant, findRelevant, findRelevant, findRelevant, generateIds, remove
-
Constructor Details
-
MilvusEmbeddingStore
public MilvusEmbeddingStore(String host, Integer port, String collectionName, Integer dimension, io.milvus.param.IndexType indexType, io.milvus.param.MetricType metricType, String uri, String token, String username, String password, io.milvus.common.clientenum.ConsistencyLevelEnum consistencyLevel, Boolean retrieveEmbeddingsOnSearch, Boolean autoFlushOnInsert, String databaseName, String idFieldName, String textFieldName, String metadataFiledName, String vectorFiledName) -
MilvusEmbeddingStore
public MilvusEmbeddingStore(io.milvus.client.MilvusServiceClient milvusClient, String collectionName, Integer dimension, io.milvus.param.IndexType indexType, io.milvus.param.MetricType metricType, io.milvus.common.clientenum.ConsistencyLevelEnum consistencyLevel, Boolean retrieveEmbeddingsOnSearch, Boolean autoFlushOnInsert, String idFieldName, String textFieldName, String metadataFiledName, String vectorFiledName)
-
-
Method Details
-
builder
-
dropCollection
-
add
Description copied from interface:EmbeddingStore
Adds a given embedding to the store.- Specified by:
add
in interfaceEmbeddingStore<TextSegment>
- Parameters:
embedding
- The embedding to be added to the store.- Returns:
- The auto-generated ID associated with the added embedding.
-
add
Description copied from interface:EmbeddingStore
Adds a given embedding to the store.- Specified by:
add
in interfaceEmbeddingStore<TextSegment>
- Parameters:
id
- The unique identifier for the embedding to be added.embedding
- The embedding to be added to the store.
-
add
Description copied from interface:EmbeddingStore
Adds a given embedding and the corresponding content that has been embedded to the store.- Specified by:
add
in interfaceEmbeddingStore<TextSegment>
- Parameters:
embedding
- The embedding to be added to the store.textSegment
- Original content that was embedded.- Returns:
- The auto-generated ID associated with the added embedding.
-
addAll
Description copied from interface:EmbeddingStore
Adds multiple embeddings to the store.- Specified by:
addAll
in interfaceEmbeddingStore<TextSegment>
- Parameters:
embeddings
- A list of embeddings to be added to the store.- Returns:
- A list of auto-generated IDs associated with the added embeddings.
-
search
Description copied from interface:EmbeddingStore
Searches for the most similar (closest in the embedding space)Embedding
s.
All search criteria are defined inside theEmbeddingSearchRequest
.
EmbeddingSearchRequest.filter()
can be used to filter by various metadata entries (e.g., user/memory ID). Please note that not allEmbeddingStore
implementations supportFilter
ing.- Specified by:
search
in interfaceEmbeddingStore<TextSegment>
- Parameters:
embeddingSearchRequest
- A request to search in anEmbeddingStore
. Contains all search criteria.- Returns:
- An
EmbeddingSearchResult
containing all foundEmbedding
s.
-
addAll
Description copied from interface:EmbeddingStore
Adds multiple embeddings and their corresponding contents that have been embedded to the store.- Specified by:
addAll
in interfaceEmbeddingStore<TextSegment>
- Parameters:
ids
- A list of IDs associated with the added embeddings.embeddings
- A list of embeddings to be added to the store.textSegments
- A list of original contents that were embedded.
-
removeAll
Removes a single embedding from the store by ID.CAUTION
- Deleted entities can still be retrieved immediately after the deletion if the consistency level is set lower than
Strong
- Entities deleted beyond the pre-specified span of time for Time Travel cannot be retrieved again.
- Frequent deletion operations will impact the system performance.
- Before deleting entities by comlpex boolean expressions, make sure the collection has been loaded.
- Deleting entities by complex boolean expressions is not an atomic operation. Therefore, if it fails halfway through, some data may still be deleted.
- Deleting entities by complex boolean expressions is supported only when the consistency is set to Bounded. For details, see Consistency
- Specified by:
removeAll
in interfaceEmbeddingStore<TextSegment>
- Parameters:
ids
- A collection of unique IDs of the embeddings to be removed.- Since:
- Milvus version 2.3.x
- Deleted entities can still be retrieved immediately after the deletion if the consistency level is set lower than
-
removeAll
Removes all embeddings that match the specifiedFilter
from the store.CAUTION
- Deleted entities can still be retrieved immediately after the deletion if the consistency level is set lower than
Strong
- Entities deleted beyond the pre-specified span of time for Time Travel cannot be retrieved again.
- Frequent deletion operations will impact the system performance.
- Before deleting entities by comlpex boolean expressions, make sure the collection has been loaded.
- Deleting entities by complex boolean expressions is not an atomic operation. Therefore, if it fails halfway through, some data may still be deleted.
- Deleting entities by complex boolean expressions is supported only when the consistency is set to Bounded. For details, see Consistency
- Specified by:
removeAll
in interfaceEmbeddingStore<TextSegment>
- Parameters:
filter
- The filter to be applied to theMetadata
of theTextSegment
during removal. Only embeddings whoseTextSegment
'sMetadata
match theFilter
will be removed.- Since:
- Milvus version 2.3.x
- Deleted entities can still be retrieved immediately after the deletion if the consistency level is set lower than
-
removeAll
public void removeAll()Removes all embeddings from the store.CAUTION
- Deleted entities can still be retrieved immediately after the deletion if the consistency level is set lower than
Strong
- Entities deleted beyond the pre-specified span of time for Time Travel cannot be retrieved again.
- Frequent deletion operations will impact the system performance.
- Before deleting entities by comlpex boolean expressions, make sure the collection has been loaded.
- Deleting entities by complex boolean expressions is not an atomic operation. Therefore, if it fails halfway through, some data may still be deleted.
- Deleting entities by complex boolean expressions is supported only when the consistency is set to Bounded. For details, see Consistency
- Specified by:
removeAll
in interfaceEmbeddingStore<TextSegment>
- Since:
- Milvus version 2.3.x
- Deleted entities can still be retrieved immediately after the deletion if the consistency level is set lower than
-