资讯专栏INFORMATION COLUMN

MongoDb一些数组操作

alin / 511人阅读

摘要:现在考虑这样一跳中的数据在中增加一条记录这个是最基本的数组操作将中为的一项的修改为这里用到了中一个神奇的站位操作符的作用是记录了中匹配到的字段的所以,它一定是和中有的字段对应使用而不必显示的先查询出相应的在这个例子中,操作符匹配出了为的中相

现在考虑这样一跳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)})
新年快乐!

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/18719.html

相关文章

  • MongoDB指南---3、MongoDB基础知识-数据类型

    摘要:如将构造函数作为函数进行调用即不包括的方式,返回的是日期的字符串表示,而非日期对象。如果不注意这一点,没有始终使用日期构造函数,将得到一堆混乱的日期对象和日期的字符串。关于日期类的完整解释,以及构造函数的参数格式,参见规范节。 上一篇文章:MongoDB指南---2、MongoDB基础知识-文档、集合、数据库、客户端下一篇文章:MongoDB指南---4、MongoDB基础知识-使用M...

    aervon 评论0 收藏0
  • MongoDB指南---3、MongoDB基础知识-数据类型

    摘要:如将构造函数作为函数进行调用即不包括的方式,返回的是日期的字符串表示,而非日期对象。如果不注意这一点,没有始终使用日期构造函数,将得到一堆混乱的日期对象和日期的字符串。关于日期类的完整解释,以及构造函数的参数格式,参见规范节。 上一篇文章:MongoDB指南---2、MongoDB基础知识-文档、集合、数据库、客户端下一篇文章:MongoDB指南---4、MongoDB基础知识-使用M...

    tunny 评论0 收藏0
  • spring-data-mongodb查询使用的一些总结

    摘要:踩到许多坑,记录下一些基于的东西吧首先。王大锤那么查询的时候,如果要根据查询班级怎么办,的查询也非常简单。详情可以查看官方文档用法 刚接触mongodb不久。踩到许多坑,记录下一些基于spring-data-mongodb的东西吧 首先。应该了解下什么情况下使用mongodb,什么情况下用mysql: 业务需要事物,使用mysql,因为mongodb不支持事物 数据量大,但是数据本身...

    jollywing 评论0 收藏0
  • spring-data-mongodb查询使用的一些总结

    摘要:踩到许多坑,记录下一些基于的东西吧首先。王大锤那么查询的时候,如果要根据查询班级怎么办,的查询也非常简单。详情可以查看官方文档用法 刚接触mongodb不久。踩到许多坑,记录下一些基于spring-data-mongodb的东西吧 首先。应该了解下什么情况下使用mongodb,什么情况下用mysql: 业务需要事物,使用mysql,因为mongodb不支持事物 数据量大,但是数据本身...

    FuisonDesign 评论0 收藏0
  • MongoDB指南---11、使用复合索引、$操作符如何使用索引、索引对象和数组、索引基数

    摘要:操作符如何使用索引有一些查询完全无法使用索引,也有一些查询能够比其他查询更高效地使用索引。有时能够使用索引,但是通常它并不知道要如何使用索引。索引对象和数组允许深入文档内部,对嵌套字段和数组建立索引。 上一篇文章:MongoDB指南---10、索引、复合索引 简介下一篇文章:MongoDB指南---12、使用explain()和hint()、何时不应该使用索引 1、使用复合索引 在多...

    saucxs 评论0 收藏0
  • MongoDB指南---11、使用复合索引、$操作符如何使用索引、索引对象和数组、索引基数

    摘要:操作符如何使用索引有一些查询完全无法使用索引,也有一些查询能够比其他查询更高效地使用索引。有时能够使用索引,但是通常它并不知道要如何使用索引。索引对象和数组允许深入文档内部,对嵌套字段和数组建立索引。 上一篇文章:MongoDB指南---10、索引、复合索引 简介下一篇文章:MongoDB指南---12、使用explain()和hint()、何时不应该使用索引 1、使用复合索引 在多...

    tomlingtm 评论0 收藏0

发表评论

0条评论

alin

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<