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!