DataStax Astra DB 是一个无服务器的
AI 就绪数据库,基于 Apache Cassandra® 构建,
通过易用的 JSON API 提供便捷访问。
配置
依赖项
使用此集成需要安装langchain-astradb 合作伙伴包:
凭证
要使用 AstraDB 向量存储,您需要先访问 AstraDB 官网,创建账户,然后创建一个新的数据库——初始化可能需要几分钟时间。 数据库初始化完成后,请获取您的连接密钥,稍后需要使用。包括:API Endpoint,例如"https://01234567-89ab-cdef-0123-456789abcdef-us-east1.apps.astra.datastax.com/"- 以及
Database Token,例如"AstraCS:aBcD123......"
keyspace(在 LangChain 组件中称为 “namespace”),可在数据库控制台的 Data Explorer 标签页中管理。如果您希望,可以在下方提示中留空,使用默认 keyspace。
初始化
创建 Astra DB 向量存储有多种方式:方式一:显式嵌入
您可以单独实例化一个langchain_core.embeddings.Embeddings 类,并将其传递给 AstraDBVectorStore 构造函数,与大多数其他 LangChain 向量存储的用法相同。
方式二:服务端嵌入(‘vectorize’)
或者,您可以使用 Astra DB 的服务端嵌入计算功能(‘vectorize’),在创建存储的服务端基础设施时直接指定嵌入模型。后续的读写操作中,嵌入计算将完全在数据库内部处理。(使用此方式前,您必须已为数据库启用所需的嵌入集成,详见文档。)方式三:从已有集合自动检测
您的 Astra DB 中可能已有一个集合(collection),可能通过其他方式(如 Astra UI 或第三方应用)预先填充了数据,您只需在 LangChain 中开始查询。这种情况下,正确的做法是在向量存储构造函数中启用autodetect_collection 模式,让类自动识别相关细节。(当然,如果您的集合没有使用 ‘vectorize’,仍然需要提供一个 Embeddings 对象。)
关于”混合搜索”的说明
Astra DB 向量存储支持在向量搜索中进行元数据搜索;此外,0.6 版本通过 findAndRerank 数据库原语引入了对_混合搜索_的完整支持:文档同时通过向量相似度搜索和基于关键词(“词法”)的搜索进行检索,然后通过重排序模型合并。这种完全在服务端处理的搜索策略可提升结果准确性,从而改善 RAG 应用的质量。混合搜索在可用时会被向量存储自动使用(当然,如果您需要,也可以手动控制)。补充说明
AstraDBVectorStore 可以通过多种方式配置;完整指南请参阅 API 参考,涵盖异步初始化、非 Astra DB 数据库、自定义索引允许/拒绝列表、手动混合搜索控制等更多内容。
显式嵌入初始化(方式一)
使用显式嵌入类实例化我们的向量存储:服务端嵌入初始化(“vectorize”,方式二)
以下示例代码假设您已:- 在 Astra DB 组织中启用了 OpenAI 集成,
- 向集成中添加了名为
"OPENAI_API_KEY"的 API Key,并将其范围限定到您正在使用的数据库。
自动检测初始化(方式三)
如果集合已存在于数据库中,且您的AstraDBVectorStore 需要使用它(进行读写操作),可以使用此模式。LangChain 组件将检查集合并自动识别相关细节。
如果集合是由 LangChain 以外的工具创建并填充的(例如通过 Astra DB Web 界面导入数据),推荐使用此方式。
自动检测模式不能与_集合_设置(如相似度指标等)共存;另一方面,如果没有使用服务端嵌入,仍然需要向构造函数传递一个 Embeddings 对象。
以下示例代码将”自动检测”方式二(“vectorize”)创建的集合,因此无需提供 Embeddings 对象。
管理向量存储
创建向量存储后,可以通过添加和删除不同条目与其进行交互。 所有与向量存储的交互均与初始化方式无关:如有需要,请修改以下代码,选择您已创建并希望测试的向量存储。向向量存储添加条目
使用add_documents 方法向向量存储添加文档。
“id” 字段可以单独通过 add_documents 的 ids=[...] 参数提供,也可以完全省略,让存储自动生成 ID。
从向量存储删除条目
使用delete 函数按 ID 删除条目。
查询向量存储
向量存储创建并填充后,您可以查询它(例如作为链或智能体的一部分)。直接查询
相似度搜索
搜索与给定文本相似的文档,并可根据需要添加元数据过滤:带分数的相似度搜索
您也可以同时返回相似度分数:指定不同的关键词查询(需要混合搜索)
注意:此代码块仅在集合支持 find-and-rerank 命令且向量存储已知晓此事实时才可运行。如果向量存储使用了支持混合搜索的集合并已检测到这一点,默认情况下在执行搜索时会使用该功能。 在这种情况下,find-and-rerank 流程中向量相似度和基于词法的检索步骤默认使用相同的查询文本,除非您为后者显式提供不同的查询:
其他搜索方法
本 notebook 未涵盖多种其他搜索方法,例如 MMR 搜索和按向量搜索。AstraDBVectorStore 中可用的所有搜索模式,请参阅 API 参考。
转换为检索器进行查询
您也可以将向量存储转换为检索器,以便在链中更方便地使用。 将向量存储转换为检索器,并使用简单查询和元数据过滤器进行调用:用于检索增强生成(RAG)
有关如何将此向量存储用于检索增强生成(RAG)的指南,请参阅以下章节: 更多内容,请查看使用 Astra DB 的完整 RAG 模板 here。清理向量存储
如果您想从 Astra DB 实例中完全删除该集合,请运行此操作。 (您存储在其中的数据将会丢失。)API 参考
有关AstraDBVectorStore 所有功能和配置的详细文档,请参阅 API 参考。
Connect these docs to Claude, VSCode, and more via MCP for real-time answers.

