mongodb作业

1.创建一个数据库 名字grade

powershell 复制代码
use grade

2.数据库中创建一个集合名字 class

powershell 复制代码
db.createCollection("class")

3.集合中插入若干数据

powershell 复制代码
db.class.insert([{name:"zhang",age:10,sex:'m',hobby:['a','b','c']}])

4.查找

查看班级所有人信息

powershell 复制代码
db.class.find()

查看班级中年龄为8岁的学生信息

powershell 复制代码
db.class.find({age:8})

查看年龄大于10岁的学生信息

powershell 复制代码
db.class.find({age:{$gt:10}})

查看年龄在 4---8岁之间的学生信息

powershell 复制代码
db.class.find({age:{$gt:4,$lte:8}})

找到年龄为6岁且为男生的学生

powershell 复制代码
db.class.find({age:6,sex:'m'})

找到年龄小于7岁或者大于10岁的学生

powershell 复制代码
db.class.find({$or:[age:{$lt:7},age:{$gt:10}]})

找到年龄是8岁或者11岁的学生

powershell 复制代码
db.class.find({age:{$in:[8,11]}})

找到兴趣爱好有两项的学生

powershell 复制代码
db.class.find({hobby:{$size:2}})

找到兴趣爱好有draw的学生

powershell 复制代码
db.class.find({hobby:"draw"})

找到既喜欢画画又喜欢跳舞的学生

powershell 复制代码
db.class.find({hobby:{$all:["draw","dance"]}})

统计爱好有三项的学生人数

powershell 复制代码
db.class.find({hobby:{$size:3}}).count()

找出本班年龄第二大的学生

powershell 复制代码
db.class.find().sort({age:-1}).skip(1).limit(1)

查看学生的兴趣范围

powershell 复制代码
db.class.distinct('hobby')

将学生按年龄排序找到年龄最大的三个

powershell 复制代码
db.class.find().sort({age:-1}).limit(3)

删除所有 年级大于12或者小于4岁的学生

powershell 复制代码
remove({$or:[{age:{$gt:12}},{age:{$lt:4}}]})

5.增加、更新、删除、统计

将小红的年龄变为8岁 兴趣爱好变为 跳舞 画画

powershell 复制代码
{$set:{age:8,hobby:['dance','draw']}}

追加小明兴趣爱好 唱歌

powershell 复制代码
{$push:{hobby:'sing'}}

小王兴趣爱好增加 吹牛 打篮球

powershell 复制代码
{$pushAll:{hobby:['吹牛','basketball']}}

小李增加爱好,跑步和唱歌,但是不要和以前的重复

powershell 复制代码
{$addToSet:{hobby:{$each:['running','sing']}}}

该班所有同学年龄加1

powershell 复制代码
update({},{$inc:{age:1}},false,true)

删除小明的sex属性

powershell 复制代码
{$unset:{sex:0}}

删除小李兴趣中的第一项

powershell 复制代码
{$pop:{hobby:-1}}

将小红兴趣中的画画爱好删除

powershell 复制代码
{$pull:{hobby:'draw'}}

增加分数域 score:{'chinese':88,'english':78,'math':98}

按照性别分组统计每组人数

powershell 复制代码
 aggregate({$group:{_id:'$sex',num:{$sum:1}}})

按照姓名分组,过滤出有重名的同学

powershell 复制代码
aggregate([{$group:{_id:'$name',num:{$sum:1}}},{$match:{num:{$gt:1}}}])

统计每名男生的语文成绩

powershell 复制代码
aggregate([{$match:{sex:'m'}},{$project:{_id:0,name:1,'score.chinese':1}}])

将女生按照英语分数降序排列

powershell 复制代码
aggregate([{$match:{sex:'w'}},{$sort:{'score.english':-1}}])
相关推荐
Coder个人博客5 小时前
Linux6.19-ARM64 mm mmap子模块深入分析
大数据·linux·安全·车载系统·系统架构·系统安全·鸿蒙系统
江畔何人初5 小时前
/etc/profile,.profile,.bashrc三者区分
linux·运维·云原生
会飞的土拨鼠呀5 小时前
Ubuntu系统缺少 iptables 工具
linux·运维·ubuntu
前端玖耀里5 小时前
详细介绍Linux命令dig和nslookup
linux·运维·服务器
呱呱巨基5 小时前
Linux 第一个系统程序 进度条
linux·c++·笔记·学习
星期五不见面5 小时前
jetson naon super使用 sudo /opt/nvidia/jetson-io/jetson-io.py 界面闪退
linux·运维·服务器
Coder个人博客5 小时前
Linux6.19-ARM64 mm hugetlbpage子模块深入分析
linux·安全·车载系统·系统架构·系统安全·鸿蒙系统·安全架构
FreeBuf_5 小时前
AutoPentestX:面向 Linux 系统的自动化渗透测试工具包
linux·运维·自动化
EverydayJoy^v^5 小时前
RH134简单知识点——第11章—— 管理网络安全
linux·网络·web安全
leiming65 小时前
Qt视频监控系统开发实战:从视频捕获到照片管理
linux·数码相机·音视频