SearchById 用于主键 id 检索。根据主键 id,搜索与其距离最近的 limit 个向量。
说明
参数 | 子参数 | 类型 | 是否必选 | 默认值 | 参数说明 |
---|---|---|---|---|---|
id | int64 | 是 | 主键 id。 | ||
searchOptions | filter | map | 否 | 过滤条件,详见标量过滤。
| |
limit | int | 否 | 10 | 检索结果数量,最大5000个。 | |
outputFields | list<string> | 否 | 过滤字段,指定要返回的标量或向量字段列表。
如果索引的距离方式为cosine,向量字段返回的向量是归一化后的向量。 | ||
partition | string/int | 否 | "default" | 子索引名称,类型与 partitionBy 的 FieldType 一致,字段值对应 partitionBy 的 FieldValue。
| |
denseWeight | float | 否 | 0.5 | 对于标量过滤检索,dense_weight 用于控制稠密向量在检索中的权重。范围为[0.2,1]。仅在检索的索引为混合索引时有效。 | |
sparseVectors | map | 否 | 稀疏向量,格式是字典,k 为 string 类型,表示关键词的字面量,v 为 float 类型,表示该关键词的权重数值。 |
// 获取指定索引,程序初始化时调用即可,无需重复调用 index, _ := service.GetIndex("go", "goIndex")
searchOption := vikingdb.NewSearchOptions().SetFilter(map[string]interface{}{"op": "range", "field": "price", "lt": 3.5}).SetLimit(5).SetOutputFields([]string{"doc_id", "like", "text_vector", "price"}).SetDenseWeight(0.5).SetSparseVectors(map[string]interface{}{"hello1": 0.01}) res, err := index.SearchById("111", searchOption) if err != nil { fmt.Println(err) } for _, item := range res { fmt.Println(item) }
Go 调用执行上面的任务,返回 Data 结构体地址构成的列表([]*Data)。Data 结构体包含的属性如下表所示。
属性 | 说明 |
---|---|
Id | 主键 id。 |
Fields | 请求返回中的 fields 字段,是具体的数据,map 类型。 |
Score | 表示找到的向量和输入的向量的匹配程度。 |