大数据技术之MongoDB学习笔记(4)查询操作
沉沙 2019-04-02 来源 : 阅读 210 评论 0

摘要:本篇文章探讨了大数据技术之MongoDB学习笔记(4)查询操作,希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。

本篇文章探讨了大数据技术之MongoDB学习笔记(4)查询操作,希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。

大数据技术之MongoDB学习笔记(4)查询操作

1、指定返回键


2、查询条件

2.1比较操作符

$lt<{age:{$gte:22,$lte:27}}
$lte<=
$gt>
$gte>=
$ne!=

2.2查询条件

查询25到27岁的学生的姓名和年龄

db.persons.find({age:{$gte:25,$lte:27}},{_id:0,name:1,age:1})

查询出所有不是韩国学生的数学成绩

db.persons.find({country:{$ne:"Korea"}},{_id:0,country:1,m:1})

2.3包含和不包含($in   $nin)

查询国籍是中国或者美国的学生的姓名和国家

db.persons.find({country:{$in:["China","USA"]}},{_id:0,name:1,country:1})

查询国籍不是中国或者美国的学生的姓名和国家

db.persons.find({country:{$nin:["China","USA"]}},{_id:0,name:1,country:1})

2.4OR查询

语文成绩大于85或者英语成绩大于90的学生信息

db.persons.find({$or:[{c:{$gt:85}},{e:{$gt:90}}]},{_id:0,name:1,c:1,e:1})

2.5NULL

查询出sex是null的学生

先将中国的学生增加性别

db.persons.update({country:"China"},{$set:{sex:"m"}},false,true)

进行查询操作

db.persons.find({sex:{$in:[null]}},{_id:0,country:1})

2.6正则查询

db.persons.find({name:/zhangsan},{_id:0,name:1})

2.7$not的使用

取反

db.person.find({name:{$not:/zhang/}},{_id:0,name:1})

2.8$all和index的应用

查询喜欢“Mongodb”和“JS”的学生

db.persons.find({books:{$all:["MONGODB","JS"]}},{_id:0,books:1,name:1})

查询第二本书是java的学生的信息

db.persons.find({"books.1":"JAVA"},{_id:0,name:1,books:1})

2.9查询指定长度的数组$size,它不能和比较符一起使用。(弊端)

db.persons.find({books:{$size:5}},{_id:0,name:1})

2.10查询jim书架上第2~4本书

db.persons.find({name:"jim"},{books:{$slice:[1,3]}})

2.11查询出最后一本书

db.persons.find({name:"jim"},{books:{$slice:-1},_id:0,name:1})

2.12文档查询

给jim添加学历文档

var jim = [{
    school :"K",
    score:"A"
},{
    school :"L",
    score:"B"
},{
    school :"J",
    score:"A+"
}]
db.persons.update({name:"jim"},{$set:{school:jim}})

查询出在K上过学的学生

db.persons.find({"school.school":"K"},{_id:0,name:1})

db.persons.find({school:{$elemMatch:{"school":"K"}}},{_id:0,name:1})

2.13$where

查询年龄大于22岁,喜欢看C++书,在K学校上过学的学生信息复杂的查询我们就可以用$where因为他是万能但是我们要尽量避免少使用它因为他会有性能的代价

db.persons.find({"$where":function(){
    //得到查询结果的每一条文档
    var books = this.books;
    //得到文档中的school对象
    var school = this.school;
    //如果年纪>=22
    if(this.age > 22){
         var php = null;
         //遍历书籍
         for ( var i = 0; i < books.length; i++) {
              if(books[i] == "C++"){
                   php = books[i];
                   //如果学校是真
                   if(school){
                        for (var j = 0; j < school.length; j++) {
                             //判断是不是在K上学
                             if(school[j].school == "K"){
                                  //返回是真
                                  return true;
                             }
                        }
                        break;
                   }
              }
         }    
    }
}})

      本文由职坐标整理发布,学习更多的相关知识,请关注职坐标IT知识库!

本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程