MongoDB字段嵌套的一些应用

MongoDB相对关系数据库而言的一个好处就是可以存JSON格式的数据,JSON格式又是可以嵌套表示,应用起来特别舒服。

最近用到了这些特性,在update时候遇到了点小障碍,在stackoverflow上找了一下解决办法,其实关键就一个”点“。

1. 嵌套插入,这个简单只要是符合格式的JSON都能嵌套插入

db.test.insert({a:{b:{c:"value"}}});

2. 查询,查询条件如果是深入到嵌套层里面的key的话,可以用点表示:

db.test.find({"a.b.c":"value"});

注意必须用引号引住(单引号和双引号都行),下同!

3. 指定嵌套查询,并返回指定嵌套key的结果集:

db.test.find({},{"a.b":1})

4. 更新db.test.update({},{$set:{"a.b.c":"updated"}});

5. C++Drivers的一些特定的场景:获得嵌套字段的值

        bo field = BSON(key << 1 << "_id" << 0);

        bo obj = dbclient->findOne(DBM_USER_DBSET, QUERY("user" << user), &field);
        be objelem = obj.getFieldDotted(key);
        info = objelem.String();

其中,key可以是"abc.efg"的形式

最后,请教一下读客:

MongoDB怎么跨表联合查询?暂时是绕开了没用这个特性,知道怎么用的朋友,请不吝赐教啊!

 

All rights reserved!

 

转载于:https://my.oschina.net/dourgulf/blog/59621

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值