1、指定返回键
c728b2d5-dc14-4668-b4b9-a7f092e1e98f.png
2、查询条件
2.1比较操作符
$lt<{age:{$gte:22,$lte:27}}
$lte<=
$gt>
$gte>=
$ne!=
1c49370e-e536-49db-a932-b3f50fbdd23d.png
ed20e279-6230-4c38-80dd-62b0c919642d.png
2.2查询条件
查询25到27岁的学生的姓名和年龄
db.persons.find({age:{$gte:25,$lte:27}},{_id:0,name:1,age:1})
2b2c7a91-192d-4c8c-8d6c-ef0b2cd038ca.png
查询出所有不是韩国学生的数学成绩
db.persons.find({country:{$ne:"Korea"}},{_id:0,country:1,m:1})
46f195d4-ea54-41ff-bd92-e762431de039.png
2.3包含和不包含($in   $nin)
查询国籍是中国或者美国的学生的姓名和国家
db.persons.find({country:{$in:["China","USA"]}},{_id:0,name:1,country:1})
3ea45aec-ad33-49ee-a107-8a4e52d825df.png
查询国籍不是中国或者美国的学生的姓名和国家
db.persons.find({country:{$nin:["China","USA"]}},{_id:0,name:1,country:1})
0ef5fa53-01c3-4c0b-adde-a9da899eae69.png
2.4OR查询
语文成绩大于85或者英语成绩大于90的学生信息
db.persons.find({$or:[{c:{$gt:85}},{e:{$gt:90}}]},{_id:0,name:1,c:1,e:1})
bf3e3159-9f7b-41e4-9084-c992179a1054.png
2.5NULL
查询出sex是null的学生
先将中国的学生增加性别
db.persons.update({country:"China"},{$set:{sex:"m"}},false,true)
进行查询操作
db.persons.find({sex:{$in:[null]}},{_id:0,country:1})
c87021f8-06dd-451d-9862-dd579bfff9ba.png
2.6正则查询
db.persons.find({name:/zhangsan},{_id:0,name:1})
69804887-0d2c-4ac6-9ebe-aa8667d6f06a.png
2.7$not的使用
取反
db.person.find({name:{$not:/zhang/}},{_id:0,name:1})
bb90d61e-c108-4875-a206-bc69d349fd99.png
2.8$all和index的应用
查询喜欢“Mongodb”和“JS”的学生
db.persons.find({books:{$all:["MONGODB","JS"]}},{_id:0,books:1,name:1})
81e15872-fdfb-4a5b-b77b-7a6f1fc65929.png
查询第二本书是java的学生的信息
db.persons.find({"books.1":"JAVA"},{_id:0,name:1,books:1})
d93a831c-e65d-4da2-b165-959a1ec1b880.png
2.9查询指定长度的数组$size,它不能和比较符一起使用。(弊端)
db.persons.find({books:{$size:5}},{_id:0,name:1})
5d75b737-9889-4f46-9d60-e1b0dac0355c.png
2.10查询jim书架上第2~4本书
db.persons.find({name:"jim"},{books:{$slice:[1,3]}})
ce306800-b5ea-4daa-9d35-35a6477674e4.png
2.11查询出最后一本书
db.persons.find({name:"jim"},{books:{$slice:-1},_id:0,name:1})
01783ece-f1eb-4fcc-9f3a-e43ebf1aae9f.png
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})
a1053111-b4c7-4d1d-b1f3-cea50e87b7cf.png
db.persons.find({school:{$elemMatch:{"school":"K"}}},{_id:0,name:1})
bfce204b-97a5-4012-9e2e-3341e25c566f.png
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;
                   }
              }
         }    
    }
}})