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 = [{
db.persons.find({school:{$elemMatch:{"school":"K"}}},{_id:0,name:1})
2.13$where查询年龄大于22岁,喜欢看C++书,在K学校上过学的学生信息复杂的查询我们就可以用$where因为他是万能但是我们要尽量避免少使用它因为他会有性能的代价
上一篇:MongoDB笔记五——插入操作
下一篇:MongoDB笔记三——更新操作