使用的mongodb版本为3.4.16
一个名叫user的集合,相当于Mysql的一个表
1.查找user集合中的所有数据:db.user.find()
相当于sql中的 select * from user
2.查找user集合中name去重的数据:db.user.distinct(‘name’)
相当于sql中的select distinct name from user
3.查找user集合中指定列name,age数据:db.user.find({},{name :1 ,age:1})
相当于sql中的select name,age from user
4.查询age=22的数据:db.user.find({age:22})
相当于sql中的select * from user where age =22
5.查询age大于22的记录:db.user.find({age: {$gt:22} })
相当于select * from user where age >22
6.查询age大于等于22的记录:db.user.find({age: {$gte:22} })
相当于select * from user where age >=22
7.查询age小于22的记录:db.user.find({age: {$lt:22} })
相当于select * from user where age <22
8.查询age小于等于22的记录:db.user.find({age: {$lte:22} })
相当于select * from user where age <=22
比较符:大于($gt),大于等于($gte),小于($lt),小于等于($lte)
9.查询年龄大于22岁且年龄小于26岁的数据:
db.user.find(age:{$gte:22,$lte:26 })
相当于sql中的select * from user where age>22 and age<26
10.查询name中包含mango的数据:db.user.find({name:/mango/})
相当于sql中的select * from user where name like “%mango%”
11.查询以mango开头的数据:db.user.find({name:/^mango/})
相当于select * from user where name like “mango%”
12.查询指定列name,age且age>25:
db.user.find({age}:{$gt:25},{name:1,age:1})
相当于select name ,age from user where age >25
13.查询前5条数据:db.user.find().limit(5)
相当于sql中的select * from user limit 5
14.查询10条以后的数据:db.user.find().skip(10)
相当于sql中的select * from user where id not in (select * from user)
15.分页查询:db.user.find().limit(10).skip(10)
相当于sql中的select * from user limit10,10
limit是pagesize,skip是pagenum
16.or查询,查询年龄是22或25的数据:
db.user.find({$or:[{age:22},{age:25}]})
相当于sql中的select * from user where age =22 or age = 25
17.查询某个结果集的记录数
db.user.find({age:{$gte:25 } }).count()
select count(*) from user where age >=25
18.不等于查询:
db.user.find({author:{$ne:a}})
相当于sql中的select * from user where author <> a
19.升序,降序
按照age升序排序:db.user.find().sort({age}:1)
按照age降序排序:db.user.find().sort({age}:-1)
1为升序,-1为降序
20.查询dimlist字段下存在url字段的数据(url字段是嵌套在dimlist字段的列表中的)
这个语句百度了好久都没查到怎么写,大神同事写出来了,又学到了
db.getcollection(‘user’).find(‘dimlist.url’:{$exists:true})