背景
今天遇到mongodb在插入数据时出现id重复毛病,具体毛病代码以下:
duplicate key error collection: index: id dup key: { : ObjectId(‘59a3b9275f063c20cc8bdec7') }',
觉得奇怪 id不是自己生成的,怎样会这样呢 。
因而查了下ObjectId 。
ObjectId 的结构
这些是 _id 的一些主要特点的摘要:
_id 是集合中文档的主键,用于辨别文档(记录)。
_id自动编入索引。指定 { _id: } 的查找将 _id 索引作为其指南。
默许情况下,_id 字段的类型为 ObjectID,是 MongoDB 的 BSON 类型之一。如果需要,用户还可以将 _id 覆盖为 ObjectID 之外的其他内容。
ObjectID 长度为 12 字节,由几个 2⑷ 字节的链组成。每一个链代表并指定文档身份的具体内容。以下的值构成了完全的 12 字节组合:
一个 4 字节的值,表示自 Unix 纪元以来的秒数
一个 3 字节的机器标识符
一个 2 字节的进程 ID
一个 3 字节的计数器,以随机值开始
通常,如果文档还没有分配 _id 值,MongoDB 将自动生成一个 _id 值。
尝试
我的代码大概是这样的 ,批量插入
Collectwrite.InsertMany(item);
后面测试了下干脆改成单个添加
foreach(var item in list)
{
Collectwrite.InsertOne(item);
}
也是报错。
Collectwrite.InsertOne(item);
Thread.Sleep(500);
再后来降速添加,毛病照旧。
解决办法
百度了一下,发现很多人都出现了类似问题,数据库的id是根据 时间戳+主机+进程号+序列生成的。重复的缘由可能有两种:
内部缘由:同时插入两条数据,致使数据库生成了同一个id值。
外部缘由:每次使用同一个变量存储区别的数据,致使数据库认为每次存储的是同一条数据,终究生成同一个id值。
以上都有个共同点,就是让数据库自己生成id值。因而干脆换个思路
自己手动添加id值,当插入的数据带有_id的字段时,mongodb就不再自动生成id。至此, mongodb重复id的问题就解决了。 item.Id = ObjectId.GenerateNewId().ToString();
Collectwrite.DeleteMany(x => x.SeasonId == seasonId);
foreach(var item in list)
{
item.Id = ObjectId.GenerateNewId().ToString();
Collectwrite.InsertOne(item);
Thread.Sleep(500);
}
}
总结
到此这篇关于教你怎么处理mongodb出现id重复问题的解决办法的文章就介绍到这了,更多相关mongodb id重复解决内容请搜索之前的文章或继续浏览下面的相关文章希望大家以后多多支持!
文章来源:丸子建站
文章标题:教你怎么处理mongodb出现id重复问题的解决办法
https://www.wanzijz.com/view/58490.html