Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs 菜单
Docs 主页
/ /

运行向量搜索查询

MongoDB Vector Search查询采用 聚合管道 的形式,该管道使用 $vectorSearch 作为第一阶段。本页介绍了 $vectorSearch 阶段的语法、选项和行为。

$vectorSearch

$vectorSearch 阶段采用包含以下字段的文档:

定义 $vectorSearch 阶段时,可以使用 exact字段指定运行近似最近邻 (ANN) 搜索还是 精确最近邻 (ENN)搜索。

$vectorSearch 必须是其所在的任何管道中的第一阶段。

$vectorSearch 不能用于视图定义和后续管道阶段:

  • $lookup 子管道 [1]

  • $facet 管道阶段

[1] 您可以将 $vectorSearch 的结果传递给此阶段。

要学习;了解有关这些MongoDB Vector Search字段类型的更多信息,请参阅如何为向量搜索的字段创建索引。

MongoDB Vector Search 为其返回的每个文档分配一个分数,该分数在 01 之间的固定范围内(其中 0 表示低相似度,1 表示高相似度)。

注意

对数据进行预筛选不会影响MongoDB Vector Search 使用 vectorSearchScore 进行$vectorSearch 查询返回的分数。

重要

筛选后的查询通常比其他等效的未筛选查询慢。

  • MongoDB Vector Search 支持 $eq 的简写形式。在简写形式中,您无需在查询中指定 $eq

    例如,考虑以下带有 $eq 的过滤器:

    "filter": { "_id": { "$eq": ObjectId("5a9427648b0beebeb69537a5") }

    这相当于以下过滤器,它使用 $eq 的简写形式:

    "filter": { "_id": ObjectId("5a9427648b0beebeb69537a5") }
  • 您可以使用 $and MQL 操作符在单个查询中指定过滤器数组。

    例如,考虑以下预过滤器,用于 genres 字段等于 Actionyear 字段值为 199920002001 的文档:

    "filter": {
    "$and": [
    { "genres": "Action" },
    { "year": { "$in": [ 1999, 2000, 2001 ] } }
    ]
    }
  • 对于模糊搜索、短语匹配、位置筛选和其他分析文本等高级筛选功能,请在 阶段使用 vectorSearch $search操作符。

在运行这些示例之前,请执行以下操作:

注意

如果您使用mongosh ,将queryVector 直接粘贴到终端可能需要一些时间,具体取决于您的机器。我们建议将向量嵌入保存在文件中,并使用mongosh load() 命令将其加载到 中。

后退

索引参考

获得技能徽章

免费掌握“向量搜索基础知识”!

了解详情

在此页面上