MongoDB 的_id 唯一性检查

2014-03-07 16:14:33 +08:00
 destec
客户提供的json里面已经含有_id字段,并且会有重复,能不能设置MongoDB使关闭对_id的唯一性检查,或者更换唯一性标识的名字呢?
7717 次点击
所在节点    MongoDB
10 条回复
binux
2014-03-07 16:46:16 +08:00
你把客户提供的json里面的_id改成id不就完了
spritevan
2014-03-07 16:55:31 +08:00
#强烈不推荐

db.createCollection(< collection_name >, { autoIndexId:false });

[ref](http://docs.mongodb.org/manual/reference/command/create/#dbcmd.create)
destec
2014-03-07 16:59:30 +08:00
@binux 要是能轻易改就没这事了。我只是负责把数据写进去,数据库到时候也不是我用啊,自己用倒是有办法。
destec
2014-03-07 17:01:46 +08:00
@spritevan 是会引起性能问题么?
binux
2014-03-07 17:06:15 +08:00
@destec 如果不改的话,直接存json stringify后的结果,不要存结构。
spritevan
2014-03-07 17:34:04 +08:00
@destec 没索引了呀,你猜会变得有多慢?
你自己再建个字段当 index 还不如听 @binux 的改名呢
9hills
2014-03-07 18:54:17 +08:00
修改mongodb源码,把_id改成别的,然后编译
destec
2014-03-07 22:57:10 +08:00
@spritevan 得,我还是试试和客户沟通下吧。
destec
2014-03-07 22:58:10 +08:00
@9hills 请收下我碎成渣的膝盖。
nimoqu
2014-03-08 13:29:30 +08:00
因为id都是唯一的uuid6类似的,可以把它更换成时间戳_随机数的方式,然后建一张index专用的文档当做索引表,映射原_id,效率也非常高

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/103288

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX