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

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

环境准备

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

导入数据

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的查询功能。通过对工资范围、部门归属以及特定条件下的员工信息查询,不仅巩固了理论知识,还增强了实际操作能力。此外,还通过一个具体的例子展示了如何批量更新符合条件的记录。通过这些练习,你将能够更加自信地处理真实世界中的数据查询需求。
接下来,我们将进一步深化对数据库操作的理解,聚焦于各种运算符的应用。

阅读全文
下载说明:
1、本站所有资源均从互联网上收集整理而来,仅供学习交流之用,因此不包含技术服务请大家谅解!
2、本站不提供任何实质性的付费和支付资源,所有需要积分下载的资源均为网站运营赞助费用或者线下劳务费用!
3、本站所有资源仅用于学习及研究使用,您必须在下载后的24小时内删除所下载资源,切勿用于商业用途,否则由此引发的法律纠纷及连带责任本站和发布者概不承担!
4、本站站内提供的所有可下载资源,本站保证未做任何负面改动(不包含修复bug和完善功能等正面优化或二次开发),但本站不保证资源的准确性、安全性和完整性,用户下载后自行斟酌,我们以交流学习为目的,并不是所有的源码都100%无错或无bug!如有链接无法下载、失效或广告,请联系客服处理!
5、本站资源除标明原创外均来自网络整理,版权归原作者或本站特约原创作者所有,如侵犯到您的合法权益,请立即告知本站,本站将及时予与删除并致以最深的歉意!
6、如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
7、如果您喜欢该资源,请支持官方正版资源,以得到更好的正版服务!
8、请您认真阅读上述内容,注册本站用户或下载本站资源即您同意上述内容!
原文链接:https://www.shuli.cc/?p=20795,转载请注明出处。
0

评论0

显示验证码
没有账号?注册  忘记密码?