Milvus踩坑笔记

本文用于记录在学习 Milvus文档时所遇到的一些Bug或报错及解决方法

参考文章:

官方demo:在Dynamic Schema的集合中插入数据

报错1:auto id enabled, id shouldn't in entities[0]

问题描述

此报错出现在Milvus官方在介绍 Dynamic Schema 时所提供的实例代码中。报错位置与信息如下:

bash 复制代码
# 6. insert data

collection.insert(data_rows)



异常信息:auto id enabled, id shouldn't in entities[0]

问题分析

很明显这是在数据插入时,id发生了异常。Milvus官方所提供的代码中对schema的定义如下:

python 复制代码
# 1. define fields
fields = [
    FieldSchema(name="id", dtype=DataType.INT64, is_primary=True, auto_id=True),
    FieldSchema(name="title", dtype=DataType.VARCHAR, max_length=512),
    FieldSchema(name="title_vector", dtype=DataType.FLOAT_VECTOR, dim=768)
]

从上述定义可知:id被设置为了自动生成(auto_id=True),而问题恰恰就出在这里。

这里再补充一下此demo中用于插入的数据格式,如下所示:

bash 复制代码
{
    'id': 0, 
    'title': 'The Reported Mortality Rate of Coronavirus Is Not Important', 
    'title_vector': [0.041732933, 0.013779674,...,-0.027564144], 
    'link': 'https://medium.com/swlh/the-reported-mortality-rate-of-coronavirus-is-not-important-369989c8d912', 
    'reading_time': 13, 
    'publication': 'The Startup', 
    'claps': 1100, 
    'responses': 18
}

可以发现数据本身已经携带了 id 值,然而此时id字段被定义为自动生成,如此一来就会造成插入时id字段报错。

解决方案

只需将 id 字段的auto_id 设置为 False 即可,如下所示:

bash 复制代码
fields = [
    FieldSchema(name="id", dtype=DataType.INT64, is_primary=True, auto_id=False),
    ...
]
相关推荐
jingling5551 分钟前
uniapp | 快速上手ThorUI组件
前端·笔记·前端框架·uni-app
lingggggaaaa1 小时前
小迪安全v2023学习笔记(八十二讲)—— Java组件安全&Solr&Shiro&Log4j&CVE复现
笔记·学习·安全
好望角雾眠1 小时前
第四阶段C#通讯开发-1:通讯基础理论,串口,通讯模式,单位转换,代码示例
开发语言·笔记·c#·串口·通讯
贝塔实验室3 小时前
两种常用的抗单粒子翻转动态刷新方法
论文阅读·经验分享·笔记·科技·学习·程序人生·fpga开发
范纹杉想快点毕业9 小时前
ZYNQ PS 端 UART 接收数据数据帧(初学者友好版)嵌入式编程 C语言 c++ 软件开发
c语言·笔记·stm32·单片机·嵌入式硬件·mcu·51单片机
茯苓gao12 小时前
STM32G4 电流环闭环
笔记·stm32·单片机·嵌入式硬件·学习
easy202012 小时前
机器学习的本质:从跑模型到真正解决问题
笔记·学习·机器学习
汇能感知13 小时前
摄像头模组在智能家居设备中的应用
经验分享·笔记·科技
shizidushu13 小时前
Graph RAG论文阅读笔记
论文阅读·笔记·graphrag
0_0梅伊阁诗人15 小时前
Django ORM 模型
开发语言·数据库·笔记·python·oracle·django