MongoDB笔记02-MongoDB基本常用命令

文章目录

  • 一、前言
  • 二、数据库操作
    • [2.1 选择和创建数据库](#2.1 选择和创建数据库)
    • [2.2 数据库的删除](#2.2 数据库的删除)
  • [3 集合操作](#3 集合操作)
    • [3.1 集合的显式创建](#3.1 集合的显式创建)
    • [3.2 集合的隐式创建](#3.2 集合的隐式创建)
    • [3.3 集合的删除](#3.3 集合的删除)
  • 四、文档基本CRUD
    • [4.1 文档的插入](#4.1 文档的插入)
      • [4.1.1 单个文档插入](#4.1.1 单个文档插入)
      • [4.1.2 批量插入](#4.1.2 批量插入)
    • [4.2 文档的基本查询](#4.2 文档的基本查询)
      • [4.2.1 查询所有](#4.2.1 查询所有)
      • [4.2.2 投影查询(Projection Query):](#4.2.2 投影查询(Projection Query):)
    • 4.3文档的更新
      • [4.3.1 覆盖的修改](#4.3.1 覆盖的修改)
      • [4.3.2 局部修改](#4.3.2 局部修改)
      • [4.3.3 批量的修改](#4.3.3 批量的修改)
      • [4.3.4 列值增长的修改](#4.3.4 列值增长的修改)
    • 4.4删除文档
  • 五、文档的常用查询
    • [5.1 统计查询](#5.1 统计查询)
    • [5.1.1 统计所有记录数:](#5.1.1 统计所有记录数:)
    • [5.1.2 按条件统计记录数:](#5.1.2 按条件统计记录数:)
    • [5.2 分页列表查询](#5.2 分页列表查询)
      • [5.2.1 limit](#5.2.1 limit)
      • [5.2.2 skip](#5.2.2 skip)
      • [5.2.3 使用limit和skip完成分页查询](#5.2.3 使用limit和skip完成分页查询)
    • 5.3排序查询
  • 六、文档的更多查询
    • [6.1 正则的复杂条件查询](#6.1 正则的复杂条件查询)
    • [6.2 比较查询](#6.2 比较查询)
    • 6.3包含查询
      • [6.3.1 in](#6.3.1 in)
      • [6.3.2 nin](#6.3.2 nin)
    • 6.4条件连接查询
      • [6.4.1 and](#6.4.1 and)
      • [6.4.2 or](#6.4.2 or)
  • 七、常用命令小结

一、前言

现在需要将项目中文章评论的数据存放到MongoDB中,文章评论的数据结构参考如下:

数据库:articledb

集合:专栏文章评论 comment

字段名称 字段含义 字段类型 备注
_id ID ObjectId 或 String MongoDB 的主键的字段
articleid 文章ID String
content 评论内容 String
userid 评论人ID String
nickname 评论人昵称 String
createdatetime 评论的日期时间 Date
likenum 点赞数 Int32
replynum 回复数 Int32
state 状态 String 0:不可见;1:可见;
parentid 上级ID String 如果为0表示文章的顶级评论

二、数据库操作

环境:windows

安装完mongodb后启动服务,在mongodb的bin文件夹下使用cmd输入以下命令进入数据库(或配置环境变量)

js 复制代码
mongo
或
mongo --host=127.0.0.1 --port=27017

2.1 选择和创建数据库

选择和创建数据库的语法格式:

js 复制代码
use 数据库名称

如果数据库不存在则自动创建,例如,以下语句创建 articledb 数据库:

js 复制代码
use articledb

查看的所有的数据库命令

js 复制代码
show dbs
或
show databases

注意: 在 MongoDB 中,集合只有在内容插入后才会创建! 就是说,创建集合(数据表)后要再插入一个文档(记录),集合才会真正创建。

查看当前正在使用的数据库命令

js 复制代码
db

MongoDB 中默认的数据库为 test,如果你没有选择数据库,集合将存放在 test 数据库中。

另外:

数据库名可以是满足以下条件的任意UTF-8字符串。

不能是空字符串("")。

不得含有' '(空格)、.、$、/、\和\0 (空字符)。

应全部小写。

最多64字节。

有一些数据库名是保留的,可以直接访问这些有特殊作用的数据库。

  • admin: 从权限的角度来看,这是"root"数据库。要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限。一些特定的服务器端命令也只能从这个数据库运行,比如列出所有的数据库或者关闭服务器。
  • local: 这个数据永远不会被复制,可以用来存储限于本地单台服务器的任意集合
  • config: 当Mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。

2.2 数据库的删除

MongoDB 删除数据库的语法格式如下:

js 复制代码
db.dropDatabase()

提示:主要用来删除已经持久化的数据库

步骤:

  1. 先切换到需要删除的数据库
  2. 使用db.dropDatabase()

3 集合操作

集合,类似关系型数据库中的表

可以显示的创建,也可以隐式的创建。

3.1 集合的显式创建

基本语法格式:

js 复制代码
db.createCollection("name")

参数说明:

name: 要创建的集合名称

例如:创建一个名为 mytest 的普通集合。

js 复制代码
db.createCollection("mytest")

查看当前库中的表:show tables命令

js 复制代码
show collections
或
show tables

集合的命名规范:

  • 集合名不能是空字符串""。
  • 集合名不能含有\0字符(空字符),这个字符表示集合名的结尾。
  • 集合名不能以"system."开头,这是为系统集合保留的前缀。
  • 用户创建的集合名字不能含有保留字符。有些驱动程序的确支持在集合名里面包含,这是因为某些系统生成的集合中包含该字符。除
  • 非你要访问这种系统创建的集合,否则千万不要在名字里出现$。

3.2 集合的隐式创建

当向一个集合中插入一个文档的时候,如果集合不存在,则会自动创建集合。

提示:通常我们使用隐式创建文档即可。

3.3 集合的删除

集合删除语法格式如下:

js 复制代码
db.collection.drop()

返回值

如果成功删除选定集合,则 drop() 方法返回 true,否则返回 false。

例如:要删除mytest集合

js 复制代码
db.mytest.drop()

四、文档基本CRUD

文档(document)的数据结构和 JSON 基本一样。

所有存储在集合中的数据都是 BSON 格式。

4.1 文档的插入

4.1.1 单个文档插入

使用insert() 或 save() 方法向集合中插入文档,语法如下

js 复制代码
db.collection.insert(
    <document or array of documents>,
    {
        writeConcern: <document>,
        ordered: <boolean>
    }
)

参数

参数 类型 说明
document document or array 要插入到集合中的文档或文档数组。((json格式)
writeConcern document 可选. A document expressing the write concern. Omit to use the default write concern.See Write Concern.Do not explicitly set the write concern for the operation if run in a transaction. To use write concern with transactions, see Transactions and Write Concern.
ordered boolean 可选。如果为真,则按顺序插入数组中的文档,如果其中一个文档出现错误,MongoDB将返回而不处理数组中的其余文档。如果为假,则执行无序插入,如果其中一个文档出现错误,则继续处理数组中的主文档。在版本2.6+中默认为true

【示例】

要向comment的集合(表)中插入一条测试数据:

js 复制代码
db.comment.insert({"articleid":"100000","content":"c是最好的语言","userid":"1001","nickname":"c","createdatetime":new Date(),"likenum":NumberInt(10),"state":null})

执行后,如下,说明插入一个数据成功了。

js 复制代码
WriteResult({ "nInserted" : 1 })

提示:

comment集合如果不存在,则会隐式创建

mongo中的数字,默认情况下是double类型,如果要存整型,必须使用函数NumberInt(整型数字),否则取出来就有问题了。

插入当前日期使用 new Date()

插入的数据没有指定 _id ,会自动生成主键值

如果某字段没值,可以赋值为null,或不写该字段。

文档键命名规范:

  1. 键不能含有\0 (空字符)。这个字符用来表示键的结尾。
  2. 和$有特别的意义,只有在特定环境下才能使用。
  3. 以下划线"_"开头的键是保留的(不是严格要求的)。

4.1.2 批量插入

语法:

js 复制代码
db.collection.insertMany(
    [ <document 1> , <document 2>, ... ],
    {
        writeConcern: <document>,
        ordered: <boolean>
    }
)

【示例】

批量插入多条文章评论:

js 复制代码
db.comment.insertMany([

{"_id":"1","articleid":"100001","content":"java是最好的语言","userid":"1002","nickname":"java",
"createdatetime":new Date("2019-08-05T22:08:15.522Z"),"likenum":NumberInt(1000),"state":"1"},

{"_id":"2","articleid":"100001","content":"python是最好的语言","userid":"1005","nickname":"python",
"createdatetime":new Date("2019-08-05T23:58:51.485Z"),"likenum":NumberInt(888),"state":"1"},

{"_id":"3","articleid":"100001","content":"C++是最好的语言","userid":"1004","nickname":"C++",
"createdatetime":new Date("2019-08-06T01:05:06.321Z"),"likenum":NumberInt(666),"state":"1"},

{"_id":"4","articleid":"100001","content":"php是最好的语言","userid":"1003","nickname":"php",
"createdatetime":new Date("2019-08-06T08:18:35.288Z"),"likenum":NumberInt(2000),"state":"1"},

{"_id":"5","articleid":"100001","content":"java是面向对象的","userid":"1003","nickname":"java",
"createdatetime":new Date("2019-08-06T11:01:02.521Z"),"likenum":NumberInt(3000),"state":"1"}

]);

提示:

插入时指定了 _id ,则主键就是该值。

如果某条数据插入失败,将会终止插入,但已经插入成功的数据不会回滚掉。

因为批量插入由于数据较多容易出现失败,因此,可以使用try catch进行异常捕捉处理,测试的时候可以不处理。

4.2 文档的基本查询

查询数据的语法格式如下:

js 复制代码
db.collection.find(<query>, [projection])

参数:

参数 类型 说明
query document 可选。使用查询运算符指定选择筛选器。若要返回集合中的所有文档,请省略此参数或传递空文档( {} )。
projection document 可选。指定要在与查询筛选器匹配的文档中返回的字段(投影)。若要返回匹配文档中的所有字段,请省略此参数。.

【示例】

4.2.1 查询所有

js 复制代码
db.comment.find()
或
db.comment.find({})

这里你会发现每条文档会有一个叫_id的字段,这个相当于我们原来关系数据库中表的主键,当你在插入文档记录时没有指定该字段,MongoDB会自动创建,其类型是ObjectID类型。

如果我们在插入文档记录时指定该字段也可以,其类型可以是ObjectID类型,也可以是MongoDB支持的任意类型。

如果我想按一定条件来查询,比如我想查询userid为1003的记录,只要在find()中添加参数即可,参数也是json格式,如下:

js 复制代码
> db.comment.find({userid:'1003'})

{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "php", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "java", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

如果你只需要返回符合条件的第一条数据,我们可以使用findOne命令来实现,语法和find一样。

如:查询用户编号是1003的记录,但只最多返回符合条件的第一条记录:

js 复制代码
> db.comment.findOne({userid:'1003'})

{
        "_id" : "4",
        "articleid" : "100001",
        "content" : "php是最好的语言",
        "userid" : "1003",
        "nickname" : "php",
        "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"),
        "likenum" : 2000,
        "state" : "1"
}

4.2.2 投影查询(Projection Query):

如果要查询结果返回部分字段,则需要使用投影查询(不显示所有字段,只显示指定的字段)。

如:查询结果只显示 _id、userid、nickname :

js 复制代码
> db.comment.find({userid:"1003"},{userid:1,nickname:1})

{ "_id" : "4", "userid" : "1003", "nickname" : "php" }
{ "_id" : "5", "userid" : "1003", "nickname" : "java" }

默认 _id 会显示。

如:查询结果只显示 userid、nickname ,不显示 _id :

js 复制代码
> db.comment.find({articleid:'100001'},{userid:1,nickname:1,_id:0})

{ "userid" : "1002", "nickname" : "java" }
{ "userid" : "1005", "nickname" : "python" }
{ "userid" : "1004", "nickname" : "C++" }
{ "userid" : "1003", "nickname" : "php" }
{ "userid" : "1003", "nickname" : "java" }

如:查询所有数据,但只显示 _id、userid、nickname :

js 复制代码
> db.comment.find({},{userid:1,nickname:1})

{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "userid" : "1001", "nickname" : "c" }
{ "_id" : "1", "userid" : "1002", "nickname" : "java" }
{ "_id" : "2", "userid" : "1005", "nickname" : "python" }
{ "_id" : "3", "userid" : "1004", "nickname" : "C++" }
{ "_id" : "4", "userid" : "1003", "nickname" : "php" }
{ "_id" : "5", "userid" : "1003", "nickname" : "java" }

4.3文档的更新

更新文档的语法:

js 复制代码
db.collection.update(query, update, options)
//或
db.collection.update(
    <query>,
    <update>,
    {
        upsert: <boolean>,
        multi: <boolean>,
        writeConcern: <document>,
        collation: <document>,
        arrayFilters: [ <filterdocument1>, ... ],
        hint: <document|string> // Available starting in MongoDB 4.2
    }
)

参数:

主要关注前四个参数即可。

参数 类型 说明
query document 更新的选择条件。可以使用与find()方法中相同的查询选择器,类似sql update查询内where后面的。。在3.0版中进行了更改:当使用upsert:true执行update()时,如果查询使用点表示法在_id字段上指定条件,则MongoDB将拒绝插入新文档。
update document or pipeline 要应用的修改。该值可以是:包含更新运算符表达式的文档,或仅包含:对的替换文档,或在MongoDB 4.2中启动聚合管道。.
upsert boolean 可选。如果设置为true,则在没有与查询条件匹配的文档时创建新文档。默认值为false,如果找不到匹配项,则不会插入新文档。
multi boolean 可选。如果设置为true,则更新符合查询条件的多个文档。如果设置为false,则更新一个文档。默认值为false。.

【示例】

4.3.1 覆盖的修改

如果我们想修改_id为1的记录,点赞量为1001,输入以下语句:

js 复制代码
db.comment.update({_id:"2"},{likenum:NumberInt(1001)})

执行后,我们会发现,这条文档除了likenum字段其它字段都不见了

js 复制代码
> db.comment.find()
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 1000, "state" : "1" }
{ "_id" : "2", "likenum" : 1001 }
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 666, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "php", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "java", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

4.3.2 局部修改

为了解决这个问题,我们需要使用修改器$set 来实现,命令如下:

我们想修改_id为1的记录,浏览量为888,输入以下语句:

js 复制代码
> db.comment.update({_id:"1"},{$set:{likenum:NumberInt(888)}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.comment.find()
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
{ "_id" : "2", "likenum" : 1001 }
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 666, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "php", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "java", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

4.3.3 批量的修改

更新所有用户为 1003 的用户的昵称为 C#

  1. 默认只修改第一条数据
js 复制代码
> db.comment.update({userid:"1003"},{$set:{nickname:"C#"}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.comment.find()
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
{ "_id" : "2", "likenum" : 1001 }
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 666, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "C#", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "java", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }
  1. 修改所有符合条件的数据
js 复制代码
> db.comment.update({userid:"1003"},{$set:{nickname:"JS"}},{multi:true})
WriteResult({ "nMatched" : 2, "nUpserted" : 0, "nModified" : 2 })
> db.comment.find()
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
{ "_id" : "2", "likenum" : 1001 }
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 666, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

提示:如果不加后面的参数,则只更新符合条件的第一条记录

4.3.4 列值增长的修改

如果我们想实现对某列值在原有值的基础上进行增加或减少,可以使用 $inc 运算符来实现。

需求:对_id为3的数据点赞数,每次递增1

js 复制代码
> db.comment.update({_id:"3"},{$inc:{likenum:NumberInt(1)}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.comment.find()
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
{ "_id" : "2", "likenum" : 1001 }
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 667, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

4.4删除文档

删除文档的语法结构:

js 复制代码
db.集合名称.remove(条件)

以下语句可以将数据全部删除,慎用

js 复制代码
db.comment.remove({})

如果删除_id=1的记录,输入以下语句

js 复制代码
> db.comment.remove({_id:"1"})
WriteResult({ "nRemoved" : 1 })
> db.comment.find()
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 667, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

五、文档的常用查询

5.1 统计查询

统计查询使用count()方法,语法如下:

js 复制代码
db.collection.count(query, options)

参数:

参数 类型 说明
query document 查询选择条件。
options document 可选。用于修改计数的额外选项。.

5.1.1 统计所有记录数:

统计comment集合的所有的记录数:

js 复制代码
> db.comment.count()
5

5.1.2 按条件统计记录数:

例如:统计userid为1003的记录条数

js 复制代码
> db.comment.count({userid:"1003"})
2

注意:默认情况下 count() 方法返回符合条件的全部记录条数

5.2 分页列表查询

可以使用limit()方法来读取指定数量的数据,使用skip()方法来跳过指定数量的数据。

基本语法如下所示:

js 复制代码
db.COLLECTION_NAME.find().limit(NUMBER).skip(NUMBER)

5.2.1 limit

如果你想返回指定条数的记录,可以在find方法后调用limit来返回结果(TopN),默认值20,例如:

js 复制代码
> db.comment.find().limit(3)
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 667, "state" : "1" }

5.2.2 skip

skip方法同样接受一个数字参数作为跳过的记录条数。(前N个不要),默认值是0

js 复制代码
> db.comment.find().skip(3)
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

5.2.3 使用limit和skip完成分页查询

分页查询:需求:每页2个,第二页开始:跳过前两条数据,接着值显示3和4条数据

js 复制代码
> db.comment.find().skip(0).limit(2)
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
> db.comment.find().skip(2).limit(2)
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 667, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
> db.comment.find().skip(4).limit(2)
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

5.3排序查询

sort() 方法对数据进行排序,sort() 方法可以通过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而 -1 是用于降序排列。

语法如下所示:

js 复制代码
db.集合名称.find().sort({KEY:1})

对userid降序排列,并对访问量进行升序排列

js 复制代码
 db.comment.find({},{userid:1,likenum:1}).sort({userid:-1,likenum:1})
{ "_id" : "3", "userid" : "1004", "likenum" : 667 }
{ "_id" : "4", "userid" : "1003", "likenum" : 2000 }
{ "_id" : "5", "userid" : "1003", "likenum" : 3000 }
{ "_id" : "1", "userid" : "1002", "likenum" : 888 }
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "userid" : "1001", "likenum" : 10 }

注意:skip(), limilt(), sort()三个放在一起执行的时候,执行的顺序是先 sort(), 然后是 skip(),最后是显示的 limit(),和命令编写顺序无关

六、文档的更多查询

6.1 正则的复杂条件查询

MongoDB的模糊查询是通过正则表达式的方式实现的。格式为:

js 复制代码
db.collection.find({field:/正则表达式/})

提示:正则表达式是js的语法,直接量的写法。

例如,我要查询评论内容包含"ava"的所有文档,代码如下:

js 复制代码
> db.comment.find({content:/ava/})
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

如果要查询评论的内容中以"c"开头的,代码如下:

js 复制代码
> db.comment.find({content:/^c/})
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }

6.2 比较查询

<, <=, >, >= 这个操作符也是很常用的,格式如下:

js 复制代码
db.集合名称.find({ "field" : { $gt: value }}) // 大于: field > value
db.集合名称.find({ "field" : { $lt: value }}) // 小于: field < value
db.集合名称.find({ "field" : { $gte: value }}) // 大于等于: field >= value
db.集合名称.find({ "field" : { $lte: value }}) // 小于等于: field <= value
db.集合名称.find({ "field" : { $ne: value }}) // 不等于: field != value

查询评论点赞数量大于700的记录

js 复制代码
> db.comment.find({likenum:{$gt:NumberInt(700)}})
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

6.3包含查询

6.3.1 in

包含使用$in操作符。 示例:查询评论的集合中userid字段包含1003或1004的文档

js 复制代码
 db.comment.find({userid:{$in:["1003","1004"]}})
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 667, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

6.3.2 nin

不包含使用$nin操作符。 示例:查询评论集合中userid字段不包含1003和1004的文档

js 复制代码
> db.comment.find({userid:{$nin:["1003","1004"]}})
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }

6.4条件连接查询

6.4.1 and

我们如果需要查询同时满足两个以上条件,需要使用$and操作符将条件进行关联。(相 当于SQL的and) 格式为:

js 复制代码
$and:[ { },{ },{ } ]

查询评论集合中likenum大于等于700 并且小于2000的文档:

js 复制代码
> db.comment.find({$and:[{likenum:{$gte:NumberInt(700)}},{likenum:{$lt:NumberInt(2000)}}]})

{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }

6.4.2 or

如果两个以上条件之间是或者的关系,我们使用$or操作符进行关联,与前面 and的使用方式相同 格式为:

js 复制代码
$or:[ { },{ },{ } ]

示例:查询评论集合中userid为1003,或者点赞数小于1000的文档记录

js 复制代码
> db.comment.find({$or:[ {userid:"1003"} ,{likenum:{$lt:1000} }]})
{ "_id" : ObjectId("67209f3337dc10d70c75655a"), "articleid" : "100000", "content" : "c是最好的语言", "userid" : "1001", "nickname" : "c", "createdatetime" : ISODate("2024-10-29T08:39:15.174Z"), "likenum" : 10, "state" : null }
{ "_id" : "1", "articleid" : "100001", "content" : "java是最好的语言", "userid" : "1002", "nickname" : "java", "createdatetime" : ISODate("2019-08-05T22:08:15.522Z"), "likenum" : 888, "state" : "1" }
{ "_id" : "3", "articleid" : "100001", "content" : "C++是最好的语言", "userid" : "1004", "nickname" : "C++", "createdatetime" : ISODate("2019-08-06T01:05:06.321Z"), "likenum" : 667, "state" : "1" }
{ "_id" : "4", "articleid" : "100001", "content" : "php是最好的语言", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T08:18:35.288Z"), "likenum" : 2000, "state" : "1" }
{ "_id" : "5", "articleid" : "100001", "content" : "java是面向对象的", "userid" : "1003", "nickname" : "JS", "createdatetime" : ISODate("2019-08-06T11:01:02.521Z"), "likenum" : 3000, "state" : "1" }

七、常用命令小结

js 复制代码
选择切换数据库:use articledb
插入数据:db.comment.insert({bson数据})
查询所有数据:db.comment.find();
条件查询数据:db.comment.find({条件})
查询符合条件的第一条记录:db.comment.findOne({条件})
查询符合条件的前几条记录:db.comment.find({条件}).limit(条数)
查询符合条件的跳过的记录:db.comment.find({条件}).skip(条数)
修改数据:db.comment.update({条件},{修改后的数据}) 或db.comment.update({条件},{$set:{要修改部分的字段:数据})
修改数据并自增某字段值:db.comment.update({条件},{$inc:{自增的字段:步进值}})
删除数据:db.comment.remove({条件})
统计查询:db.comment.count({条件})
模糊查询:db.comment.find({字段名:/正则表达式/})
条件比较运算:db.comment.find({字段名:{$gt:值}})
包含查询:db.comment.find({字段名:{$in:[值1,值2]}})或db.comment.find({字段名:{$nin:[值1,值2]}})
条件连接查询:db.comment.find({$and:[{条件1},{条件2}]})或db.comment.find({$or:[{条件1},{条件2}]})

全部文章:
MongoDB笔记01-概念与安装
MongoDB笔记02-MongoDB基本常用命令
MongoDB笔记03-MongoDB索引
MongoDB笔记04-SpringBoot整合MongoDB

相关推荐
Victor3565 分钟前
MongoDB(43)什么是嵌入式文档?
后端
Darkdreams31 分钟前
SpringBoot项目集成ONLYOFFICE
java·spring boot·后端
北寻北爱36 分钟前
vue2和vue3使用less和scss
前端·less·scss
NineData1 小时前
杭州 OpenClaw 开发者聚会来了!NineData 叶正盛将带来主题分享
数据库·人工智能
bropro1 小时前
【Spring Boot】Spring AOP中的环绕通知
spring boot·后端·spring
lhbian1 小时前
【Spring Cloud Alibaba】基于Spring Boot 3.x 搭建教程
java·spring boot·后端
蒸蒸yyyyzwd1 小时前
高并发40问学习笔记
笔记·学习
IT_陈寒1 小时前
Redis性能提升3倍的5个冷门技巧,90%开发者都不知道!
前端·人工智能·后端
LucianaiB1 小时前
OpenClaw 安装后必看!你真的会科学养虾吗?第1天和第47天的Openclaw有什么区别?
后端
雨雨雨雨雨别下啦1 小时前
Vue案例——面经
前端·javascript·vue.js