时间:2021-07-01 10:21:17 帮助过:30人阅读
db.stu.find({age:{$gte:18}})
使用"$in","$nin"判断是否在某个范围内
查询年龄为18、28的学生
db.stu.find({age:{$in:{19,28,38}}})
$not
语法: { field: { $not: {
$nor额外比较
考虑入校操作:
db.inventory.find( { $nor: [ { price: 1.99 }, { qty: { $lt: 20 } }, { sale: true } ] }
inventory集合查询所有的文档,条件如下:
字段price不等于1.99,字段qty不小于20,字段sale不等于true;查询的结果包含不存在的字段;
db.stu.find({age:{$gte:18},gender:true})
db.stu.find({$or:[{age:{$gt:18}},{gender:false}]})
db.stu.find({$or:[{age:{$gt:18}},{gender:true}],name:‘gj‘})
使用//或$regex编写正则表达式
查询姓黄的学生
db.produces.find({sku:/^abc/})
db.produces.find({sku:{$regex:‘789$‘})
db.stu.find().limit(2)
db.stu.find().skip(2)
使用$where后面写一个函数,返回满足条件的数据查询年龄大于30的学生
db.stu.find({
$where:function() {
return this.age>30;
}
})
在查询到的返回结果中,只选择必要的字段
db.集合名称.find({},{字段名称:1,...})
参数为字段与值,值为1表示显示,值为0不显
特殊:对于_id列默认是显示的,如果不显示需要明确设置为0
db.stu.find({},{_id:0,name:1,gender:1})
方法sort(),用于对集进行排序
db.集合名称.find().sort({字段:1,...})
参数1为升序排列
参数-1为降序排列
根据性别降序,再根据年龄升序
db.stu.find().sort({gender:-1,age:1})
方法count()用于统计结果集中文档条数
db.集合名称.find({条件}).count()
db.集合名称.count({条件})
db.stu.find({gender:true}).count()
db.tu.count({age:{$gt:20},gender:true})
方法distinct()对数据进行去重
db.集合名称.distinct(‘去重字段‘,{条件})
db.stu.distinct(‘distinct‘,{age:{$gt:18}})
mongodb高级查询
标签:ODB 运算 大于 投影 高级 ... 判断 比较 文档