MongoDb一些数组操作

现在考虑这样一跳mongo中的数据:

BSON>>>db.test.find({.....});
{_id:ObjectId(xxxxxxxx), fields:[{id:1, name:"name1", content:"xxx"}, {id:2, name:"name2", content:"yyy"}, {id:3, name:"name3", content:"zzz"}]}

在fields中增加一条记录:

这个是最基本的mongodb数组操作:

BSON>>>db.test.update({id:ObjectId(xxxxxxxx)}, {$push:{$fields:{id"4, name:"name4", "content":"aaaa"}}});
>>>db.test.find({id:ObjectId(xxxxxxxx)})
{_id:ObjectId(xxxxxxxx), fields:[{id:1, name:"name1", content:"xxx"}, {id:2, name:"name2", content:"yyy"}, {id:3, name:"name3", content:"zzz"},{id"4, name:"name4", "content":"aaaa"}]}

将fields中id为2的一项的content修改为abc

这里用到了mongodb中一个神奇的站位操作符$,$的作用是记录了where中匹配到的字段的offset(所以,它一定是和where中有的字段对应使用)而不必显示的先查询出相应的offset

BSON>>>db.test.update({id:ObjectId(xxxxxxxx), fields.id:2}, {$set:{fileds.$.set:{content:abc}}})

在这个例子中,$操作符匹配出了id为2的fields中相应的项而不需要显示的查询出来,当然,如果where中没有fields.id:2, 就会报错

删除fields中id为2的一项

为什么不先讲query?看看怎么删除的就懂了:

BSONdb.test.update({id:ObjectId(xxxxxxxx)}, {$pull:{$id: 2}})

我一直和别人说,mongo中的冒号绝对不是简单的等于

mongo中神奇的“:”

这是一个常见的mongo中存子引用的建立关联的例子:假设一个team的ducument,存储了member的id的list

BSON>>>db.team.find()
{id:ObjectId(xxx), member_list:[ObjectId(11111), ObjectId(22222), ObjectId(333333)]};

现在知道一个member的id为ObjectId(22222),查询相应的team信息是根本不需要什么$in之类的操作符的:

BSON>>>db.team.find({member_list:ObjectId(22222)})

新年快乐!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值