设为首页 收藏本站
查看: 1005|回复: 0

[经验分享] mongoDB基本操作(二)-(CRUD)

[复制链接]

尚未签到

发表于 2018-10-26 12:38:10 | 显示全部楼层 |阅读模式
  MongoDB的shell操作数据,用到create、read、update、delete操作。
  1、创建
  insert函数用于创建一个文档到集合里面。
  例,创建局部变量post,内容是代表文档的JavaScript对象,里面会有title、content和date几个键。
  > post = {"title":"My Blog Post",
  ... "content":"Here's my blog post",
  ... "date":new Date()}
  {
  "title" : "My Blog Post",
  "content" : "Here's my blog post",
  "date" : ISODate("2015-02-02T05:04:55.861Z")
  }
  > db
  test
  使用insert方法保存到集合blog中,注意,这时blog并不存在。
  > db.blog.insert(post)
  WriteResult({ "nInserted" : 1 })
  2、读取
  find()函数会读取集合中的所有文档:
  > db.blog.find();
  { "_id" : ObjectId("54cf05c00eb7b5f5718da826"), "title" : "My Blog Post", "conte
  nt" : "Here's my blog post", "date" : ISODate("2015-02-02T05:04:55.861Z") }
  若是只想查看一个文档,使用findOne()
  > db.blog.findone();
  2015-02-02T13:10:15.365+0800 TypeError: Property 'findone' of object test.blog i
  s not a function
  > db.blog.findOne();
  {
  "_id" : ObjectId("54cf05c00eb7b5f5718da826"),
  "title" : "My Blog Post",
  "content" : "Here's my blog post",
  "date" : ISODate("2015-02-02T05:04:55.861Z")
  }
  3、更新
  3.1
  update接受至少两个参数:一是更新文档的限定条件,二是新的文档。假设决定给先前写的文章增加评论内容,则需要增加一个新的键,对应的值是存放评论的数组:
  修改变量post,增加"comment"键:
  > post.comments = [];
  [ ]
  执行update
  > db.blog.update({"title":"My Blog Post"},post)
  WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
  > db.blog.find();
  { "_id" : ObjectId("54cf05c00eb7b5f5718da826"), "title" : "My Blog Post", "conte
  nt" : "Here's my blog post", "date" : ISODate("2015-02-02T05:04:55.861Z"), "comm
  ents" : [ ] }
  > db.blog.findOne();
  {
  "_id" : ObjectId("54cf05c00eb7b5f5718da826"),
  "title" : "My Blog Post",
  "content" : "Here's my blog post",
  "date" : ISODate("2015-02-02T05:04:55.861Z"),
  "comments" : [ ]
  }
  3.2使用修改器("$inc"修改器)
  通常文档只会有一部分要更新,利用原子的更新修改器,可以使得这种部分更新极为高效。更新修改器是种特殊的键,用来指定复杂的更新操作,比如调整、增加或者删除键,还可能是操作数组或者内嵌文档。
  再看更新一例:
  > db.people.find();
  { "_id" : ObjectId("54d08f7f0eb7b5f5718da82a"), "name" : "joe", "age" : 65 }
  { "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 20 }
  { "_id" : ObjectId("54d08fbd0eb7b5f5718da82c"), "name" : "joe", "age" : 49 }
  > db.people.update({"age":20},{"$inc":{"age":1}});
  WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
  > db.people.find();
  { "_id" : ObjectId("54d08a1d0eb7b5f5718da828"), "name" : "joe", "friends" : 32,
  "enemies" : 2 }
  { "_id" : ObjectId("54d08f7f0eb7b5f5718da82a"), "name" : "joe", "age" : 65 }
  { "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }
  { "_id" : ObjectId("54d08fbd0eb7b5f5718da82c"), "name" : "joe", "age" : 49 }
  >
  4、删除
  remove用来从数据库中永久性地删除文档,在不适用参数进行调用的情况下,它会删除一个集合内的所有文档,也可以接受一个文档以指定限制条件:
  > db.blog.remove({"title":"My Blog Post"});
  WriteResult({ "nRemoved" : 1 })
  > db.blog.find();
  >
  删除是永久性的,不能撤销,也不能恢复。
  删除文档通常都很快,但是要清除整个集合,直接删除集合(然后重建索引)会更快。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-626781-1-1.html 上篇帖子: 【MongoDB学习笔记31】MongoDB配置副本集 下篇帖子: mongodb的导入/导出/备份/还原
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表