Mongodb的的增删改查


1. mongodb插入数据

命令:db.集合名称.insert(document)   【document要用大括号包起来】

db.stu.insert({name:'gj', gender:1})    #  可加引号可不加,终端会自动给加上的
db.stu.insert({_id:"20170101", name:'gj', gender:1})

插文档时,如果不指定_id参数,MongoDB会为文档自动分配一个唯一的ObjectId

2. mongodb的保存

命令:db.集合名称.save(document)

db.stu.save({_id:'20170101', name:'gj', gender:2})
db.stu.save({name:'gj', gender:2})
db.stu.find()

【拿着_id去查找后面的数据是否一样,一样则保存,若不一样则修改,若没有则插入】

如果文档的_id已经存在则修改,如果_id不存在则添加

3 mongodb的查询

命令:db.集合名称.find()   【不加条件的话,查询出所有的数据】

可以使用以下数据进行练习:

db.stu.insert([{"name" : "郭靖", "hometown" : "蒙古", "age" : 20, "gender" : true },
{"name" : "黄蓉", "hometown" : "桃花岛", "age" : 18, "gender" : false },
{"name" : "华筝", "hometown" : "蒙古", "age" : 18, "gender" : false },
{"name" : "黄药师", "hometown" : "桃花岛", "age" : 40, "gender" : true },
{"name" : "段誉", "hometown" : "大理", "age" : 16, "gender" : true },
{"name" : "段王爷", "hometown" : "大理", "age" : 45, "gender" : true },
{"name" : "洪七公", "hometown" : "华筝", "age" : 18, "gender" : true }])

3.1 简单查询

  • 方法find(): 查询

    db.集合名称.find({条件文档})

  • 方法findOne():查询,只返回第一个

    db.集合名称.findOne({条件文档})

  • 方法pretty(): 将结果格式化;不能和findOne()一起使用!

    db.集合名称.find({条件文档}).pretty()

3.2 比较运算符

  • 等于: 默认是等于判断, 没有运算符  【等于的话就是键值对】
  • 小于:$lt (less than)
  • 小于等于:$lte (less than equal)
  • 大于:$gt (greater than)
  • 大于等于:$gte
  • 不等于:$ne
查询年龄大于18的所有学生
db.stu.find({age:{$gte:18}})

3.3 逻辑运算符    【多个条件的逻辑关系】

逻辑运算符主要指与、或逻辑

  • and:在json中写多个条件即可
查询年龄大于或等于18, 并且性别为true的学生
db.stu.find({age:{$gte:18},gender:true})
  • or:使用$or, 值为数组, 数组中每个元素为json
查询年龄大于18, 或性别为false的学生
db.stu.find({$or:[{age:{$gt:18}},{gender:false}]})查询年龄大于18或性别为男生, 并且姓名是郭靖
db.stu.find({$or:[{age:{$gte:18}},{gender:true}],name:'gj'})

3.4 范围运算符

使用$in, $nin 判断数据是否在某个数组内

查询年龄为18、 28的学生
db.stu.find({age:{$in:[18,28,38]}})

3.5 支持正则表达式

使用$regex编写正则表达式  【就相当于模糊查询的一种】【正则表达式是对字符串进行处理,存的值必须是字符串才能做处理】

查询name以'黄'开头的数据
db.stu.find({name:{$regex:'^黄'}})

3.6 自定义查询

mongo shell 是一个js的执行环境 使用$where 写一个函数, 返回满足条件的数据

查询年龄大于30的学生
db.stu.find({$where:function() {return this.age>30;}
})

3.7 skip和limit   【让mongodb做分页操作】

  • 方法limit(): 用于读取指定数量的文档

    db.集合名称.find().limit(NUMBER)
    查询2条学生信息
    db.stu.find().limit(2)
    
  • 方法skip(): 用于跳过指定数量的⽂档

    db.集合名称.find().skip(NUMBER)
    db.stu.find().skip(2)
    
  • 同时使用

    db.stu.find().limit(4).skip(5)
    db.stu.find().skip(5).limit(4)
    

注意:先使用skip在使用limit的效率要高于前者     【skip的优先级要高于limit,不管谁写写在前面都是先执行skip】

3.8 投影

在查询到的返回结果中, 只选择必要的字段

命令:db.集合名称.find({},{字段名称:1,...})

参数为字段与值, 值为1表示显示, 值为0不显 特别注意:

  • 对于_id列默认是显示的, 如果不显示需要明确设置为0
  • 对于其他不显示的字段不能设置为0

db.stu.find({},{_id:0,name:1,gender:1})

3.9 排序

方法sort(), 用于对查询结果按照指定的字段进行排序

命令:db.集合名称.find().sort({字段:1,...})

参数1为升序排列 参数-1为降序排列

根据性别降序, 再根据年龄升序
db.stu.find().sort({gender:-1,age:1})

3.10 统计个数

方法count()用于统计结果集中文档条数

命令:db.集合名称.find({条件}).count() 命令:db.集合名称.count({条件})

db.stu.find({gender:true}).count()
db.stu.count({age:{$gt:20},gender:true})

3.11去重

4 mongodb的更新

db.集合名称.update({query}, {update}, {multi: boolean})
  • 参数query:查询条件
  • 参数update:更新操作符
  • 参数multi:可选,默认是false,表示只更新找到的第一条数据,值为true表示把满足条件的数据全部更新
db.stu.update({name:'hr'},{name:'mnc'})           # 全文档进行覆盖更新
db.stu.update({name:'hr'},{$set:{name:'hys'}})    # 指定键值更新操作
db.stu.update({},{$set:{gender:0}},{multi:true})  # 更新全部

注意:"multi update only works with $ operators"

  • multi参数必须和$set一起使用!

【按住Ctrl+a,光标就可以直接跳到最前方】

5 mongodb的删除

db.集合名称.remove({query}, {justOne: boolean})
- 参数query:可选,删除的⽂档的条件
- 参数justOne:可选, 如果设为true或1,则只删除一条,默认false,表示删除全部

小结

  1. mongo shell中的增 db.集合名.insert({数据}) db.集合名.save({包含_id的完整数据}) # 根据指定的_id进行保存,存在则更新,不存在则插入
  2. mongo shell中的删 db.集合名.remove({条件}, {justOne: true/false})
  3. mongo shell中的改 db.集合名.update({条件}, {$set:{完整数据/部分字段}}, {multi: true/false})
  4. mongo shell中的查 db.集合名.find({条件}, {字段投影})

Mongodb的的增删改查相关推荐

  1. 利用koa实现mongodb数据库的增删改查

    概述 使用koa免不了要操纵数据库,现阶段流行的数据库是mongoDB,所以我研究了一下koa里面mongoDB数据库的增删改查,记录下来,供以后开发时参考,相信对其他人也有用. 源代码请看:我的gi ...

  2. Mongodb命令操作增删改查

    Mongodb命令操作增删改查 需求描述 新增5 人 查询 修改 删除 数据结构 {"_id" : ObjectId("59f938235d93fc4af8a37114& ...

  3. express+mongodb+vue实现增删改查-全栈之路

    vue element mongodb express 效果图 前言 最近一直想学下node,毕竟会node的前端更有市场.但是光看不练,感觉还是少了点什么,就去github上看别人写的项目,收获颇丰 ...

  4. Node.js+Express+MongoDB 实现学生增删改查

    前言 选用Node.js,Express,MongoDB来实现一个学生信息的增删改查. Express框架搭建服务器 art-template模板实现页面 MongoDB数据库 Mongoose操作数 ...

  5. nodejs对mongodb数据库的增删改查操作(转载)

    首先要确保mongodb的正确安装,安装参照:http://docs.mongodb.org/manual/tutorial/install-mongodb-on-debian-or-ubuntu-l ...

  6. mongodb数据库的增删改查(有图有demo)

    名词注释 下面的截图中,有一些名词需要解释一下,方便理解和应用: cuckoo叫库名,也就是数据库的名字 users叫集合名,也就是colloction的名字 右侧带_id的一排排的, 那叫文档 而_ ...

  7. Java操作Mongodb数据(增删改查聚合查询)

    文章目录 一.Java操作MongoDB 二.使用步骤 1.基础配置 2.实体类 3.MongoDB表数据 3.增删改查聚合查询 总结 一.Java操作MongoDB 上一篇文章介绍了,如何在本地使用 ...

  8. java创建mongdb数据库_【转发】Java使用MongoDB数据库进行增删改查

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/qq_26584263/article/ ...

  9. express+mongodb+vue实现增删改查-全栈之路2.0

    Github项目地址 效果图 登陆页 查询 新增 修改 删除 详情页 技术栈 vue axios vue-router express mongo element iconfont scss 前言 半 ...

最新文章

  1. mac好用大java_好用,小个头大本事!Mac下轻量级清理软件。
  2. spring中getBeansWithAnnotation(Class<? extends Annotation> annotationType)方法
  3. 畅通工程,How Many Tables ACM第九天-图论
  4. Android加速度传感器实现“摇一摇”,带手机振动
  5. JavaScript Development Toolkit 简介
  6. Kappa电商负责人顾皓澜:电商业务一直保持盈利
  7. 常用数据库连接串与驱动总结
  8. 围绕央行系统升级所产生的常见问题
  9. java List和数组转换
  10. 苹果发布 iOS、macOS 更新,系统修复英特尔重大漏洞
  11. pycharm 显示空格及tab
  12. 如何卸载密码保护的Symantec Endpoint Protection
  13. Asp.net中模仿Winform的MessageBox
  14. C语言算三角形外心坐标,三角形外心坐标公式(含C语言代码)
  15. python赋值01_少说话多写代码之Python学习022——赋值语句的用户01(序列解包)...
  16. @2017-2018 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2017) K:Kayaking Trip(二分+贪心)
  17. Quorum入门2.0:Quorum-企业以太坊-开始尝试
  18. Unity iOS包打出的app名称空格丢失
  19. 浅尝Clickhouse
  20. 沈阳市计算机学校1996届,生命科学学院1996届应用生物班校友回母校举行毕业20周年联谊会...

热门文章

  1. 170亿参数加持,微软发布史上最大Transformer模型
  2. PyTorch踩过的12坑 | CSDN博文精选
  3. Hinton胶囊理论代码开源,上线即受热捧
  4. IDEA + Vim = 得劲
  5. 面试官问:为什么SpringBoot的 jar 可以直接运行?
  6. 面试:SpringBoot中的条件注解底层是如何实现的?
  7. 万众赋能工业4.0:三一数据应用大赛圆满落幕
  8. 提高 GPU 训练利用率的Tricks
  9. CSDN博客的创建及使用
  10. 深入浅出统计学(十)抽取样本