MongoDBByteStore#
- class langchain_community.storage.mongodb.MongoDBByteStore(connection_string: str, db_name: str, collection_name: str, *, client_kwargs: dict | None = None)[source]#
BaseStore implementation using MongoDB as the underlying store.
Examples
Create a MongoDBByteStore instance and perform operations on it:
# Instantiate the MongoDBByteStore with a MongoDB connection from langchain.storage import MongoDBByteStore mongo_conn_str = "mongodb://localhost:27017/" mongodb_store = MongoDBBytesStore(mongo_conn_str, db_name="test-db", collection_name="test-collection") # Set values for keys mongodb_store.mset([("key1", "hello"), ("key2", "workd")]) # Get values for keys values = mongodb_store.mget(["key1", "key2"]) # [bytes1, bytes1] # Iterate over keys for key in mongodb_store.yield_keys(): print(key) # Delete keys mongodb_store.mdelete(["key1", "key2"])
Initialize the MongoDBStore with a MongoDB connection string.
- Parameters:
connection_string (str) – MongoDB connection string
db_name (str) – name to use
collection_name (str) – collection name to use
client_kwargs (dict) – Keyword arguments to pass to the Mongo client
Methods
__init__
(connection_string, db_name, ...[, ...])Initialize the MongoDBStore with a MongoDB connection string.
amdelete
(keys)Async delete the given keys and their associated values.
amget
(keys)Async get the values associated with the given keys.
amset
(key_value_pairs)Async set the values for the given keys.
ayield_keys
(*[, prefix])Async get an iterator over keys that match the given prefix.
mdelete
(keys)Delete the given ids.
mget
(keys)Get the list of documents associated with the given keys.
mset
(key_value_pairs)Set the given key-value pairs.
yield_keys
([prefix])Yield keys in the store.
- __init__(connection_string: str, db_name: str, collection_name: str, *, client_kwargs: dict | None = None) None [source]#
Initialize the MongoDBStore with a MongoDB connection string.
- Parameters:
connection_string (str) – MongoDB connection string
db_name (str) – name to use
collection_name (str) – collection name to use
client_kwargs (dict) – Keyword arguments to pass to the Mongo client
- Return type:
None
- async amdelete(keys: Sequence[K]) None #
Async delete the given keys and their associated values.
- Parameters:
keys (Sequence[K]) – A sequence of keys to delete.
- Return type:
None
- async amget(keys: Sequence[K]) List[V | None] #
Async get the values associated with the given keys.
- Parameters:
keys (Sequence[K]) – A sequence of keys.
- Returns:
A sequence of optional values associated with the keys. If a key is not found, the corresponding value will be None.
- Return type:
List[V | None]
- async amset(key_value_pairs: Sequence[Tuple[K, V]]) None #
Async set the values for the given keys.
- Parameters:
key_value_pairs (Sequence[Tuple[K, V]]) – A sequence of key-value pairs.
- Return type:
None
- async ayield_keys(*, prefix: str | None = None) AsyncIterator[K] | AsyncIterator[str] #
Async get an iterator over keys that match the given prefix.
- Parameters:
prefix (str) – The prefix to match.
- Yields:
Iterator[K | str] – An iterator over keys that match the given prefix. This method is allowed to return an iterator over either K or str depending on what makes more sense for the given store.
- Return type:
AsyncIterator[K] | AsyncIterator[str]
- mdelete(keys: Sequence[str]) None [source]#
Delete the given ids.
- Parameters:
keys (list[str]) – A list of keys representing Document IDs..
- Return type:
None
- mget(keys: Sequence[str]) List[bytes | None] [source]#
Get the list of documents associated with the given keys.
- Parameters:
keys (list[str]) – A list of keys representing Document IDs..
- Returns:
- A list of Documents corresponding to the provided
keys, where each Document is either retrieved successfully or represented as None if not found.
- Return type:
list[Document]