Mongodb常用查询语句_笔记

目录

  • 前言
  • 一、Mongodb简介
  • 二、Mongodb常用查询语句
  • 总结


前言

工作中会使用到Mongodb数据库,这是一个非关系型数据库,所以它的一些查询语句跟sql会不太一样,一时半会不能马上写出来,因此做了一些笔记,希望做出一些输出的内容。

一、Mongodb简介

Mongodb常用查询语句_笔记_第1张图片

MongoDB与SQL名词对比
Mongodb常用查询语句_笔记_第2张图片

二、Mongodb常用查询语句

使用的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})

总结

以上就是今天分享的内容,本文仅仅简单介绍了我工作中经常使用到的Mongodb数据库查询语句的使用,还有一些聚合的操作后面尽量会更新,有不对的地方请批评指正。

你可能感兴趣的:(笔记,mongodb,数据库)