mongodb 修改主键类型
程序员文章站
2022-05-21 12:36:25
公司不知道出于什么原因使用Mongodb存储业务数据,而且是比较老得版本,造成了后面一系列问题。没有事务导致后台繁忙时数据不一致。主键默认ObjectId导致查询失败,需要手动设置,并且为字符串,防止自动转换为ObjectId。自带一套查询语句,导致有学习成本。今天遇到的问题就是因为主键为ObjectId导致后台查询出错。原因为写代码忘记设置_id,mongo自动插入id并且是ObjectId。既然线上已经出错了,我就要解决了。查询mongodb语法,得到如下语句。db.table.find(...
公司不知道出于什么原因使用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使用数字对应不同类型:具体如下
类型 | 数字 | 备注 |
---|---|---|
Double | 1 | 双精度浮点数 - 此类型用于存储浮点值 |
String | 2 | 字符串 - 这是用于存储数据的最常用的数据类型。MongoDB中的字符串必须为UTF-8 |
Object | 3 | 对象 - 此数据类型用于嵌入式文档 |
Array | 4 | 数组 - 此类型用于将数组或列表或多个值存储到一个键中 |
Binary data | 5 | 二进制数据 - 此数据类型用于存储二进制数据 |
Undefined | 6 | 已废弃 |
Object id | 7 | 对象ID - 此数据类型用于存储文档的ID |
Boolean | 8 | 布尔类型 - 此类型用于存储布尔值(true / false)值 |
Date | 9 | 日期 - 此数据类型用于以UNIX时间格式存储当前日期或时间。可以通过创建日期对象并将日,月,年的日期进行指定自己需要的日期时间 |
Math.random()为mongo内置函数用于生成随机数。
后面加update是为了避免被转换为ObjectId,设置为String类型。
执行过之后,并不会将旧的ObjectId数据删掉,会插入一条新的数据,_id为string类型。
所以还需要将旧数据删掉。
db.rMBRecord.remove({_id:{$type:7}});
本文地址:https://blog.csdn.net/GY325416/article/details/107313418
推荐阅读
-
Mysql LONGBLOB 类型存储二进制数据 (修改+调试+整理)
-
Mysql LONGTEXT 类型存储大文件(二进制也可以) (修改+调试+整理)
-
python修改list中所有元素类型的三种方法
-
通过C#调用cmd来修改服务启动类型
-
mysql 如何修改、添加、删除表主键
-
php操作MongoDB基础教程(连接、新增、修改、删除、查询)
-
修改nginx服务器类型实现简单伪装(隐藏nginx类型与版本等)
-
MongoDB 执行mongoexport时异常及分析(关于数字类型的查询)
-
Oracle修改字段类型报错:“ORA-01439:要更改数据类型,则要修改的列必须为空”
-
MongoDB执行mongoexport时的异常及分析(数字类型的查询)