第6章 练中学,学中练:MongoDB综合查询实战

2,617 阅读2分钟

在上一章【# 动手吧!MongoDB 插入文档的性能优化:单个、多个、批量及分批次插入】中,我们详细介绍了掌握如何在MongoDB中更高效地插入文档,我们需要深入了解文档级别的CRUD操作细节,并探讨如何在实践中优化性能。通过本章的实践指导,希望你能掌握查询方面的技能,为后续的数据管理打下坚实的基础。

环境准备

  • Mongodb服务正常运行
  • 已安装Navicat Premium
  • 已完成数据库corp
  • 导入emp.jsondep.json

导入数据(关键四步)

第一步 image.png 第二步 image.png 第三步

image.png 第四步

image.png

任务描述

1.查询工资小于2000的员工

2.查询工资在1000-2000之间的员工

3.查询工资小于1000或大于2500的员工

4.查询财务部的所有员工

5.查询销售部的所有员工

6.查询所有mgr为7698的所有员工

7.为所有薪资低于1000的员工增加工资400元

任务实施

1.查询工资小于2000的员工
db.emp.find({sal:{$lt:2000}})
或
db.emp.find({"$where":"this.sal<2000"});
2查询工资在1000-2000之间的员工 
db.emp.find({sal:{$lt:2000,$gt:1000}})
或
db.emp.find({"$where":"this.sal<2000&&this.sal>1000"});
或
db.emp.find({"$and": [
  {"$where" : "this.sal > 1000"},
  {"$where" : "this.sal < 2000"}
]}).pretty()

3.查询工资小于1000或大于2500的员工 
db.emp.find({$or:[{sal:{$lt:1000}},{sal:{$gt:2500}}]})
或
db.emp.find({"$or": [
  {"$where" : "this.sal > 2500"},
  {"$where" : "this.sal < 1000"}
]}).pretty()

4.查询财务部的所有员工 
var depnum = db.dept.findOne({dname:"财务部"}).deptno
db.emp.find({depno:depnum})
或db.emp.find({depno:db.dept.findOne({dname:"财务部"}).deptno})

5.查询销售部的所有员工
var depnum = db.dept.findOne({dname:"销售部"}).deptno 
db.emp.find({depno:depnum})

6.查询所有mgr为7698的所有员工
db.emp.find({mgr:7698})
或
db.emp.find({"$where":"this.mgr==7698"})

7.为所有薪资低于1000的员工增加工资400元 
db.emp.updateMany({sal:{$lte:1000}},{$inc:{sal:400}}) 
或
db.emp.update({sal:{$lte:1000}},{$inc:{sal:400}},{multi:true});
db.emp.find({})

巩固练习

  1. 详细阅读文档:https://www.mongodb.com/zh-cn/docs/v5.0/crud/
  2. 利用思维导图总结任务二:MongoDB查询操作

在本章中,我们通过一系列实际操作,深入探讨了MongoDB中的查询技巧。从基本的条件筛选到复杂的逻辑组合查询,每个任务都旨在帮助你更好地理解和掌握MongoDB的查询功能。通过对工资范围、部门归属以及特定条件下的员工信息查询,不仅巩固了理论知识,还增强了实际操作能力。此外,还通过一个具体的例子展示了如何批量更新符合条件的记录。通过这些练习,你将能够更加自信地处理真实世界中的数据查询需求。 接下来,我们将进一步深化对数据库操作的理解,聚焦于各种运算符的应用。