mongodb 修改主键类型

9 篇文章 0 订阅

公司不知道出于什么原因使用Mongodb存储业务数据,而且是比较老得版本,造成了后面一系列问题。
没有事务导致后台繁忙时数据不一致。
主键默认ObjectId导致查询失败,需要手动设置,并且为字符串,防止自动转换为ObjectId。
自带一套查询语句,导致有学习成本。

今天遇到的问题就是因为主键为ObjectId导致后台查询出错。原因为写代码忘记设置_id,mongo自动插入id并且是ObjectId。

既然线上已经出错了,我就要解决了。
查询mongodb语法,得到如下语句。

db.table.find({_id:{$type:7}}).forEach(function(x){
  	x._id = (Math.random()*1000000000000000)+"update";
	db.table.save(x);
});

mongo使用数字对应不同类型:具体如下

类型数字备注
Double1双精度浮点数 - 此类型用于存储浮点值
String2字符串 - 这是用于存储数据的最常用的数据类型。MongoDB中的字符串必须为UTF-8
Object3对象 - 此数据类型用于嵌入式文档
Array4数组 - 此类型用于将数组或列表或多个值存储到一个键中
Binary data5二进制数据 - 此数据类型用于存储二进制数据
Undefined6已废弃
Object id7对象ID - 此数据类型用于存储文档的ID
Boolean8布尔类型 - 此类型用于存储布尔值(true / false)值
Date9日期 - 此数据类型用于以UNIX时间格式存储当前日期或时间。可以通过创建日期对象并将日,月,年的日期进行指定自己需要的日期时间

Math.random()为mongo内置函数用于生成随机数。
后面加update是为了避免被转换为ObjectId,设置为String类型。

执行过之后,并不会将旧的ObjectId数据删掉,会插入一条新的数据,_id为string类型。
所以还需要将旧数据删掉。

db.rMBRecord.remove({_id:{$type:7}});
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值