mongodb自定义字段,如何更改字段在Mongodb中添加一个子字段

I have mongo documents like the following:

{

"_id" : ObjectId("591e36eb2cdce09936d8e511"),

"bday" : null,

"studentId" : "000004"

}

I want to make it :

{

"_id" : ObjectId("591e36eb2cdce09936d8e511"),

"bday" : null,

"studentId" : {

"id" : "000004"

}

}

I have tried the following:

db.persons.update({"studentId": "000004"},{$set : {"studentId.id": "000004"}},false,true)

But it is giving an error:

LEFT_SUBFIELD only supports Object: studentId not: 2

Can anyone help?

Thanks,

Sumit.

解决方案

In your case you see an error because you are trying to take "studentId" which is string and add a property inside it. To fix it you should set entire new object like this

db.persons.update({"studentId":"000004"},{$set:{"studentId":{"id":"000004"}}})

Another option, if, for example you need to change structure for entire collection, is to just iterate over each element and update them. Like this:

db.persons.find({}).forEach(function (item) {

if (item.studentId != null){

item.studentId = {id:item.studentId};

db.persons.save(item);

}

});

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值