插入文档:
SQL语句:
INSERT INTO 表名 (列名.......) VALUES(对应的列值.........);
MongoDB语句:
db.集合名.insert({键:值,键:值,键:值.........})


db.集合名.save({键:值,键:值,键:值........})
save()方法和insert()方法的区别在于,save会先判断集合当中是否存在相同的文档,如果存在不执行插入,如果不存在则执行插入。
删除文档:
SQL语句:
DELETE FROM 表名 WHERE 条件
MongoDB语句:
db.集合名.remove({匹配条件})
修改文档:
SQL语句:
UPDATE 表名 SET 列名=值 WHERE 条件
MongoDB语句:
db.表名.update({条件},{要更改的内容},upsert,是否批量修改)
在MongoDB中,update方法有四个参数:
第一个参数:是匹配条件,与SQL语句当中的where条件一样
第二个参数:更新内容,要更改成什么样,写在这里
第三个参数:upsert,如果为true,那集合中有满足第一个条件的文档,就执行更新,如果没有满足第一个条件的文档,就执行插入以条件为内容的新文档,再更新成第二个参数。
第四个参数:如果设为true,则更新所有满足以第一个参数为条件的文档,否则,只更新一条。
好,那么我来给大家说下MongoDB当中常用的修改器:
1.$set 修改器
使用方法:db.collname.update({"name":"捷哥浅谈PHP"},{'$set':{"name":"捷哥浅谈MongoDB"}},0,1)
这条命令的意思是:将满足name为"捷哥浅谈PHP"的文档的name键更改成"捷哥浅谈MongoDB"
例如:我们原来的文档为:{"name":"捷哥浅谈PHP","age":1,"total":11}
更新以后的文档为:{"name":"捷哥浅谈MongoDB","age":1,"total":11}
如果我们不加$set,直接写成:db.collname.update({"name":"捷哥浅谈PHP"},{"name":"捷哥浅谈MongoDB"},0,1)
大家想想会是什么样的结果?
如果不加$set的话,更新后的文档将会是:
{"name":"捷哥浅谈MongoDB"}
其他的键都会被”干掉“,只留下name键,这显然不是我们想要的结果,所以在update方法中,$set是最常用的修改器。
2.$unset 修改器
说到unset,还记得PHP当中的unset()函数吗,它的功能是删除一个已声明的变量。
同样,在我们的MongoDB当中,$unset是删除文档当中的一个键
使用方法:db.collname.update({"name":"捷哥浅谈PHP"},{'$unset':{"age":1}},0,1)
更新后的文档:{"name":"捷哥浅谈PHP","total":11}
age键会被删除掉。
3.$inc 增加或减少
使用方法:db.collname.update({"name":"捷哥浅谈PHP"},{'$inc':{"total":1}},0,1)
意思是让total键自增1,写几就自增几,如果为负数,即为自减
更新后的文档:
{"name":"捷哥浅谈PHP","age":1,"total":12}
童鞋们考虑一下,如果我现在有这样一个微博的文档,内含每个人的评论信息:

  1. {
  2. "title":"捷哥浅谈PHP",
  3. "content":"捷哥浅谈PHP篇篇文章经典",
  4. "comm":[
  5. {
  6. "name":"打酱油的",
  7. "content":"捷哥太强啦!"
  8. },
  9. {
  10. "name":"赵桐正",
  11. "content":"这个系列文章太好啦!"
  12. },
  13. {
  14. "name":"李强强",
  15. "content":"很好的帮助了我"
  16. }
  17. ]
  18. }

如果有一个新的用户“李文凯”,来评论这条微博,内容为:“内容很精彩,千万不要错过哦!”,该怎么样往这条微博里面插入。
这就用到了咱们的数组修改器:
我们来看:
1.$push 修改器
作用:向数组末尾插入一个元素,如果没有就创建一个新的数组
使用方法:db.collname.update({"name":"捷哥浅谈PHP"},{'$push':{"comm":{"name":"李文凯",content:"内容很精彩,千万不要错过哦!"}}})
更新后的文档为:

  1. {
  2. "title":"捷哥浅谈PHP",
  3. "content":"捷哥浅谈PHP篇篇文章经典",
  4. "comm":[
  5. {
  6. "name":"打酱油的",
  7. "content":"捷哥太强啦!"
  8. },
  9. {
  10. "name":"赵桐正",
  11. "content":"这个系列文章太好啦!"
  12. },
  13. {
  14. "name":"李强强",
  15. "content":"很好的帮助了我"
  16. },
  17. {
  18. "name":"李文凯",
  19. "content":"内容很精彩,千万不要错过哦!"
  20. }
  21. ]
  22. }

童鞋们,如果我现在有这样的需求,如果用户“李文凯”已经评论过此微博,我们就不让其再进行评论,大家思考一下,要怎么做?
我们是否可以通过判断来做,先写一个伪代码,------》如果评论内容中存在要更新的新评论,即name和content的值在评论当中已经存在,我们就不执行更新,否则则更新插入name为“李文凯”的新评论,这样可以有效的防止灌水。
好,我们用代码来实现:
db.collname.update({"name":" 李文凯","comm":{'$ne':{"name":"李文凯","content":"内容很精彩,千万不要错过哦!"}}},{'$push' :{"comm":{"name":"李文凯",content:"内容很精彩,千万不要错过哦!"}}});
这样判断会造成很大的麻烦,我们的$addToSet修改器本身就带有这样的功能,我们来试试:
2.$addToSet修改器
要完成以上需求,我们可以这样来做:
db.collname.update({"name":"李文凯"},{'$addToSet' :{"comm":{"name":"李文凯",content:"内容很精彩,千万不要错过哦!"}}});
大家可以看到,$addToSet前面不需要进行判断,就能达到我们的$ne配合$push完成的效果。
如果我们现在要更改评论里面的name为“李文凯”的评论内容,我们需要使用数组的定位修改器$:
db.collname.update({"comm.name":"李文凯"},{'$set':{"comm.$.content":"我是李小凯"}})
大家再考虑这样一个问题,如果我们的一个用户集合当中,存在一个用户文档,里面有姓名,性别,年龄,爱好(以数组的形式存储)等键,例如:

  1. {
  2. "name":"捷哥",
  3. "sex":"纯爷们",
  4. "age":27,
  5. "hobby":[
  6. "football",
  7. "basketball",
  8. "sing"
  9. ]
  10. }

我们现在有这样一个需求,在网页当中如果用户勾选了某些爱好的复选框,我们就批量执行插入这些爱好。
有些童鞋会这样想,我们使用$push或者$addToSet直接插入数组就行:
db.user.update({"name":"捷哥"},{'$push':{"hobby":["PHP","JAVA"]}})
大家认为这样可以吗?答案是否定的,执行该条语句后的结果为:

  1. {
  2. "name":"捷哥",
  3. "sex":"纯爷们",
  4. "age":27,
  5. "hobby":[
  6. "football",
  7. "basketball",
  8. "sing",
  9. [
  10. "PHP",
  11. "JAVA"
  12. ]
  13. ]
  14. }

这显然不是我们想要的结果,这样就需要我们使用$each来配合$addToSet来使用。
3.$each
我们来看$each,这里我们这样来实现:
db.user.update({"name":"捷哥"},{'$addToSet':{"hobby":{'$each':["PHP","JAVA"]}}})
这样我们更新后的文档为:

  1. {
  2. "name":"捷哥",
  3. "sex":"纯爷们",
  4. "age":27,
  5. "hobby":[
  6. "football",
  7. "basketball",
  8. "sing",
  9. "PHP",
  10. "JAVA"
  11. ]
  12. }

正如童鞋们所见,这样的结果才是我们想要的结果。
注意:$each不能使用$push配合使用,只能使用$addToSet。
4.$pop 修改器
作用:删除数组的第一个元素或者最后一个元素
使用方法:db.user.update({"name":"捷哥"},{'$pop':{"hobby":1}});
修改后的文档就会变成:

  1. {
  2. "name":"捷哥",
  3. "sex":"纯爷们",
  4. "age":27,
  5. "hobby":[
  6. "football",
  7. "basketball",
  8. "sing",
  9. "PHP"
  10. ]
  11. }

“1”表示从数组末尾删除一个元素,“-1”表示从数组开头删除一个元素,因此,
db.user.update({"name":"捷哥"},{'$pop':{"hobby":-1}});
运行后的文档更新为:

  1. {
  2. "name":"捷哥",
  3. "sex":"纯爷们",
  4. "age":27,
  5. "hobby":[
  6. "basketball",
  7. "sing",
  8. "PHP",
  9. "JAVA"
  10. ]
  11. }

那如果我们现在要删除爱好里面的“sing”,这个元素既不是开头第一个元素,也不是末尾的最后一个元素,显然我们使用$pop已经满足不了这个需求了,这时我们就需要使用$pull修改器了。
5.$pull 修改器
作用:删除数组当中的指定元素
使用方法:db.user.update({"name":"捷哥"},{'$pull':{"hobby":"sing"}})
以上文档修改以后的文档就会变成:

  1. {
  2. "name":"捷哥",
  3. "sex":"纯爷们",
  4. "age":27,
  5. "hobby":[
  6. "basketball",
  7. "PHP",
  8. "JAVA"
  9. ]
  10. }

由此可见,$pull可以删除数组中的指定的元素,也就是说我们可以任意删除指定的爱好兴趣。
好了,今天把我们常用的修改器都给大家讲了一下,不知道大家都能看明白吗,有问题的话可以跟帖回复提问,也可以给我发邮件lijie@lampbrother.net

本文转自94cool博客园博客,原文链接:http://www.cnblogs.com/94cool/p/6186326.html,如需转载请自行联系原作者

MongoDB数据库的CURD的一些基本语句相关推荐

  1. java连接mongodb_第78天: Python 操作 MongoDB 数据库介绍

    MongoDB 是一款面向文档型的 NoSQL 数据库,是一个基于分布式文件存储的开源的非关系型数据库系统,其内容是以 K/V 形式存储,结构不固定,它的字段值可以包含其他文档.数组和文档数组等.其采 ...

  2. Mongodb 数据库基本操作语句,结合 Node.js + express + mongoose (实现增、删、改、查,批量增加、修改等,创建临时表,多表查询......)

    版本说明 "MongoDB": "4.0.9", // cmd命令窗输入:mongo --version "node": 10.13.0, ...

  3. mongodb数据库的常用命令

    MongoDB - 连接 启动 MongoDB 服务 在前面的教程中,我们已经讨论了如何启动 MongoDB 服务,你只需要在 MongoDB 安装目录的 bin 目录下执行 mongod 即可. 执 ...

  4. python操作mongodb数据库

    2019独角兽企业重金招聘Python工程师标准>>> 一.MongoDB 数据库操作 连接数据库 import pymongo conn = pymongo.Connection( ...

  5. 如何连接mongodb数据库,并且从中查找数据

    最近在需要从mongodb中查找出数据,但是连接mongodb也是刚刚接触到,所有如何连接mongdb然后从中查找出数据 之前从https://www.cnblogs.com/minsons/arti ...

  6. mongoDB 数据库简介

    背景概念-数据库类型 对比关系型数据库 优点 : 逻辑清晰.容易理解,结构类似表格 使用 sql 语句技术成熟,使用方便 数据一致性好,完整性好 关系型数据库比较成熟,可以使用一些复杂操作 缺点 : ...

  7. 关于MongoDB数据库的总结

    既然要说MongoDB数据库,先引入NoSQL的概念. NoSQL: NoSQL,指的是非关系型的数据库.NoSQL有时也称作Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系 ...

  8. mongodb数据库扩展名_MongoDB学习笔记:MongoDB 数据库的命名、设计规范

    第一部分,我们先说命名规范. 文档 设计约束 UTF-8 字符 不能包含 \0 字符(空字符),这个字符标识建的结尾 . 和 $ 有特殊含义,需要避免 区分大小写 键不能重复 键/值对有序 实践约束 ...

  9. MongoDB数据库(8.Python中使用mongodb数据库以及pymongo模块用法)

    在Python中使用MongoDB数据库,首先要下载pymongo模块 直接在命令行   pip install pymongo   就可以了 Python中使用pymongo模块对MongoDB数据 ...

最新文章

  1. html %3c% page,page.html
  2. sql--找含有制定字符列的表
  3. mysql 怎么导入函数_mysql导入导出包括函数或者存储过程_MySQL
  4. 使用OpenCV与百度OCR C++ SDK实现文字识别
  5. vb制作可输出函数的通用DLL---VB_DLL_Link用法
  6. PHP部分字符串函数汇总
  7. mysql弄丢初始密码_MySql密码丢失
  8. QT事件过滤器eventFilter函数
  9. oracle新增表单,Oracle Retail(Retek)中Form生成列表方法总结
  10. (68)Vue-cli 目录与文件
  11. 【Elasticsearch】class_cast_exception KeywordFieldMapper cannot be cast to ObjectMapper
  12. Rider找不到指定的 SDK Microsoft.NET.Sdk
  13. css怎么写链接到图片和地址
  14. pycharm查看关键词的方法
  15. NPM酷库:minimatch,模式匹配字符串
  16. java 批量删除_mybatis批量插入、批量更新和批量删除
  17. Nacos集群(二)阿里自研弱一致性Distro协议核心实现
  18. yota3无第三方recovery root方法
  19. 老王论坛蓝色大屏幕调节亮度
  20. python:select interpreter resulted in an error python.setINterpreter not found

热门文章

  1. 将位图转换为矢量图形:
  2. 如何理解服装产业链及供应链
  3. 基于Kinect Azure的多相机数据采集(三)
  4. 毕业设计--基于深度学习的常见苹果叶片病害识别与病斑分割方法研究
  5. 最全最详细的大数据组件介绍
  6. 数据可视化,python英雄联盟个人能力值雷达图绘制。
  7. bash: Is :command not found的解决方法和思考总结
  8. logstash mysql报错_elk系列教程:logstash报错处理
  9. 河北有哪学计算机的好的大学,河北省有哪些好点的大学?
  10. 用10000个电极窃听大脑