1、创建一年级的3个班,并随机添加 10 名学生;

>for(grade_index in (grade = ['grade_1_1', 'grade_1_2', 'grade_1_3'])) {
hobbys=['draw', 'dance', 'running', 'sing', 'football', 'basketball', 'computer', 'python']
for (var i = 1; i <= 10; i++) {
db[grade[grade_index]].insert({
"name": "zhangsan" + i,
"sex": Math.round(Math.random() * 10) % 2,
"age": Math.round(Math.random() * 6) + 3,
"hobby": [Hobbys[Math.round(Math.random() * 6)]]
});
}
} 

查看

查看一年级二班grade_1_2中的所有学生

db.getCollection('grade_1_2').find({})

查看一年级二班grade_1_2中所有年龄是 4 岁的学生

db.getCollection('grade_1_2').find({"age": 4})

查看一年级二班grade_1_2中所有年龄大于 4 岁的学生

db.getCollection('grade_1_2').find({"age": {$gt: 4}})

查看一年级二班grade_1_2中所有年龄大于 4 岁并且小于 7 岁的学生

db.getCollection('grade_1_2').find({"age": {$gt: 4, $lt: 7}})

查看一年级二班grade_1_2中所有年龄大于 4 岁并且性别值为0的学生

db.getCollection('grade_1_2').find({"age": {$gt: 4}, "sex": 0})

查看一年级二班grade_1_2中所有年龄小于 4 岁或者大于 7 岁的学生

db.getCollection('grade_1_2').find({$or: [{"age": {$lt: 4}}, {"age": {$gt: 6}}]})

查看一年级二班grade_1_2中所有年龄是 4 岁或 6 岁的学生

db.getCollection('grade_1_2').find({"age": {$in: [4, 6]}})

查看一年级二班grade_1_2中所有姓名带zhangsan1的学生

db.getCollection('grade_1_2').find({"name": {$regex: "zhangsan1"}})

查看一年级二班grade_1_2中所有姓名带zhangsan1和zhangsan2的学生

db.getCollection('grade_1_2').find({"name": {$in: [new RegExp(""zhangsan1"), new RegExp(""zhangsan2")]}}) 

查看一年级二班grade_1_2中所有兴趣爱好有三项的学生

db.getCollection('grade_1_2').find({"hobby": {$size: 3}}) 

查看一年级二班`grade_1_2`中所有兴趣爱好包括画画的学生

db.getCollection('grade_1_2').find({"hobby": "drawing"})

查看一年级二班`grade_1_2`中所有兴趣爱好既包括画画又包括跳舞的学生

db.getCollection('grade_1_2').find({"hobby": {$all: ["drawing", "dance"]}}) 

查看一年级二班grade_1_2中所有兴趣爱好有三项的学生的学生数目

db.getCollection('grade_1_2').find({"hobby": {$size: 3}}).count() 

查看一年级二班的第二位学生

db.getCollection('grade_1_2').find({}).limit(1).skip(1) 

查看一年级二班的学生,按年纪升序

db.getCollection('grade_1_2').find({}).sort({"age": 1}) 

查看一年级二班的学生,按年纪降序

db.getCollection('grade_1_2').find({}).sort({"age": -1}) 

查看一年级二班的学生,年龄值有哪些

db.getCollection('grade_1_2').distinct('age')  

查看一年级二班的学生,兴趣覆盖范围有哪些

db.getCollection('grade_1_2').distinct('hobby')  

查看一年级二班的学生,男生(`sex`为 0)年龄值有哪些

db.getCollection('grade_1_2').distinct('age', {"sex": 0})

删除

一年级二班grade_1_2, 删除所有 4 岁的学生

db.getCollection('grade_1_2').remove({"age": 4})  

一年级二班grade_1_2, 删除第一位 6 岁的学生

db.getCollection('grade_1_2').remove({"age": 6}, {justOne: 1})  

修改

一年级二班grade_1_2中,修改名为zhangsan7的学生,年龄为 8 岁,兴趣爱好为 跳舞和画画;

db.getCollection('grade_1_2').update({"name": "zhangsan7"}, {$set: {"age": 8, "hobby": ["dance", "drawing"]}}) 

一年级二班`grade_1_2`中,追加zhangsan7`学生兴趣爱好唱歌;

db.getCollection('grade_1_2').update({"name": "zhangsan7"}, {$push: {"hobby": "sing"}}) 

一年级二班`grade_1_2`中,追加zhangsan7`学生兴趣爱好吹牛和打篮球;

db.getCollection('grade_1_2').update({"name": "zhangsan7"}, {$push: {"hobby": {$each: ["brag", "play_basketball"]}}}) 

一年级二班`grade_1_2`中,追加`zhangsan7`学生兴趣爱好唱歌和打篮球,要保证`hobby`数组不重复;

db.getCollection('grade_1_2').update({"name": "zhangsan7"}, {$addToSet: {"hobby": {$each: ["sing1", "play_basketball"]}}})  

新学年,给一年级二班所有学生的年龄都增加一岁

db.getCollection('grade_1_2').update({}, {$inc: {"age": 1}}, {multi: true})  

一年级二班grade_1_2中,删除zhangsan7学生的sex属性

db.getCollection('grade_1_2').update({"name": "zhangsan7"}, {$unset: {"sex": 1}}) 

一年级二班grade_1_2中,删除zhangsan7学生的hobby数组中的头元素

db.getCollection('grade_1_2').update({"name": "zhangsan7"}, {$pop: {"hobby": -1}})  

一年级二班`grade_1_2`中,删除`zhangsan7`学生的`hobby`数组中的尾元素

db.getCollection('grade_1_2').update({"name": "zhangsan7"}, {$pop: {"hobby": 1}})  

一年级二班`grade_1_2`中,删除`zhangsan7`学生的`hobby`数组中的`sing`元素

db.getCollection('grade_1_2').update({"name": "zhangsan7"}, {$pull: {"hobby": "sing"}}  

分组

新建一个集合grade_1_4,记录一年级四班在期中考试时的成绩;

 for (var i = 1; i <= 10; i++) {

        db.grade_1_4.insert({

            "name": "zhangsan" + i,

            "sex": Math.round(Math.random() * 10) % 2,

            "age": Math.round(Math.random() * 6) + 3,

            "score": {

                "chinese": 60 + Math.round(Math.random() * 40),

                "math": 60 + Math.round(Math.random() * 40),

                "english": 60 + Math.round(Math.random() * 40)

            }

        });

    }  

统计每名学生在考试中的总分

 db.grade_1_4.group({

       key: {"name": 1},

       cond: {},

       reduce: function(curr, result) {

result.total += curr.score.chinese + curr.score.math + curr.score.english;

       },

       initial: { total : 0 }

   })

统计每名男生在考试中的总分

  db.grade_1_4.group({

       key: {"name": 1},

       cond: {"sex": 0},

       reduce: function(curr, result) {

result.total += curr.score.chinese + curr.score.math + curr.score.english;

       },

       initial: { total : 0 }

   })  

统计每名男生在考试中的总分及平均分

 db.grade_1_4.group({

       key: {"name": 1},

       cond: {"sex": 0},

       reduce: function(curr, result) {

result.total += curr.score.chinese + curr.score.math + curr.score.english;

       },

       initial: { total : 0 },

       finalize: function(item) {

item.avg = (item.total / 3).toFixed(2);

return item;
}
})  

聚合

根据姓名分组, 并统计人数

db.getCollection('grade_1_4').aggregate([{$group: {_id: "$name", num: {$sum: 1}}}])  

根据姓名分组, 并统计人数,过滤人数大于 1 的学生

 db.getCollection('grade_1_4').aggregate([

       {$group: {_id: "$name", num: {$sum: 1}}},

       {$match: {num: {$gt: 1}}}

   ])

统计每名学生在考试中的总分

   db.getCollection('grade_1_4').aggregate([

       {$group: {_id: "$name", score: {$sum: {$sum: ["$score.chinese", "$score.math", "$score.english"]}}}}

])

统计每名男生在考试中的总分

db.getCollection('grade_1_4').aggregate([

   {$match: {sex: 0}},

   {$group: {_id: "$name", score: {$sum: {$sum: ["$score.chinese", "$score.math", "$score.english"]}}}}

])

统计每名男生在考试中的总分, 总分降序

db.getCollection('grade_1_4').aggregate([

       {$match: {sex: 0}},

       {$group: {_id: "$name", score: {$sum: {$sum: ["$score.chinese", "$score.math", "$score.english"]}}}},

       {$sort: {score: 1}}

])

MongoDB数据操作练习的更多相关文章

  1. 笔记-mongodb数据操作

    笔记-mongodb数据操作 1.      数据操作 1.1.    插入 db.COLLECTION_NAME.insert(document) 案例: db.inventory.insertOn ...

  2. EasyUI-datagrid数据展示+MongoDB数据操作

    使用EasyUI-datagrid进行数据展示:进行添加,修改,删除操作逻辑代码,数据源来自MongoDB. 一.新建SiteInfo控制器,添加Index页面:http://www.cnblogs. ...

  3. mongodb 数据操作CRUD

    链接到mongo 新建超级用户 上文中我们提到mongo用户库表管理.为了方便我们先新建一个root权限的用户. db.createUser({user:'dbadmin',pwd:'123456', ...

  4. mongodb数据操作(CRUD)

    1.数据插入db.集合名.insert() 操作 > use hk switched to db hk > show collections > db.info.insert({&q ...

  5. MongoDB数据操作之删除与游标处理

    删除数据(比较常用) 范例:清空infos集合中的内容.表.文档.成员. db.infos.remove({"url":/-/}); 默认情况下都删除,第二个条件设为true,只删 ...

  6. Mongodb数据操作基础

    var mongodb = require('mongodb'); var server = new mongodb.Server('localhost', 27017, {auto_reconnec ...

  7. mongodb 数据操作(1)

    切换/创建数据库 use test 添加数据db.student.save({name:"J33ack",age:25}) 查看数据库show dbs 删除当前数据库 db.dro ...

  8. mongodb 数据操作(2)

    查询 db.student.find({}) 查询db.student.find({name:"李强1"}) 查询   条件查询 db.student.find({sex:&quo ...

  9. MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB数据

    看到下图,是通过Jqgrid实现表格数据的基本增删查改的操作.表格数据增删改是一般企业应用系统开发的常见功能,不过不同的是这个表格数据来源是非关系型的数据库MongoDB.nosql虽然概念新颖,但是 ...

随机推荐

  1. JS存取Cookies值

    这里对cookie进行了说明,也介绍了几个方法,但是我要取我存的cookie时取不到,他的方法只是针对存的  名字-值,不涉及键,所以自己写了个方法,来满足我的需求. 封装了简单存取Cookie: / ...

  2. Python处理数据集-1

    原数据集的数据格式: 每行为:(test_User, test_Item) negativeItem1 negativeItem2 negativeItem3 …… negativeItem99 即每 ...

  3. ROS源更改

    ROS源更改 配置你的电脑使其能够安装来自 packages.ros.org 的软件,使用国内或者新加坡的镜像源,这样能够大大提高安装下载速度 sudo sh -c '. /etc/lsb-relea ...

  4. HttpInvoker GET/POST方式

    1.GET方式 HttpGet httpGet = new HttpGet("http://localhost:8080/randomCode/getSouthUuid"); St ...

  5. mybatis 报Invalid bound statement(not found) 和 Property 'mapperLocations' was not specified or not matching resources found

    排除问题的步骤: 1.首先检查mapper文件和mapper接口的文件名是否相等. 2.pom.xml是否把xml排除了,这样写就会src/main/java下所有的Mybatis的xml文件都删除, ...

  6. 英语AmbraGrisea龙涎香

    龙涎香AmbraGrisea是抹香鲸科动物抹香鲸的肠内分泌物的干燥品.取自宰杀的抹香鲸肠内分泌物(即鲸鱼的粪便,它是抹香鲸吞食墨鱼后,胃肠道分泌出来的灰黑色的蜡状排泄物).其味甘.气腥.性涩,具有行气 ...

  7. 【软件工程第三次作业】结对编程:四则运算( Java 实现)

    1. GitHub 地址 本项目由 莫少政(3117004667).余泽端(3117004679)结对完成. 项目 GitHub 地址:https://github.com/Yuzeduan/Arit ...

  8. 面试官:讲讲redis的过期策略如何实现?

    时隔多日,小菜鸡终于接到阿里的面试通知,屁颠屁颠的从上海赶到了杭州. 经过半个小时的厮杀: 自我介绍 hashMap和ConcurrentHashMap区别 jdk中锁的实现原理 volatile的使 ...

  9. mysql的常用查询创建命令

    查看所有数据库Show databases;创建数据库Create database 数据库名删除数据库Drop database 数据库名创建表CREATE TABLE t_bookType(   ...

  10. Kotlin开发springboot项目(三)

    Kotlin开发springboot项目(三) 在线工具 https://www.sojson.com IDEA中Kotlin生成可执行文件1,项目使用Gradle构建2,在model的build.g ...