继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

mongo变更数据类型

阿丽是我
关注TA
已关注
手记 9
粉丝 0
获赞 7

mongo写入加了引号,导致一些数值字段都是string类型,修改字段类型为数值型。

db.Report99.find().forEach(
    function(doc){
        db.Report99.update({'_id': doc._id},{$set:{"begin-quantity": parseFloat(doc["begin-quantity"])}}); //改为浮点数
        db.Report99.update({'_id': doc._id},{$set:{"end-quantity": NumberInt(doc["end-quantity"])}}); // 改为整型
    }
);

mongo4.2+版本,可参数如下方式:

db.getCollection("my-report").update(
    {
        "begin-quantity": { $type: "string" }
    },
    [{ $set: { "begin-quantity": { $convert: { input: "$average-quantity", to: "double" } } } }],  //有效类型: string|bool|int|long|double|decimal|date|timestamp|objectId ...
    { multi: true }
)

说明:
1、如果集合名包含特殊字符,使用db.getCollection(‘my-report’)
2、forEach中doc取某个字段值可直接doc.key,如果key中包含特殊字符,使用doc[’’]

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP