MongoDB--文档基本CRUD

373 阅读5分钟

一.文档的插入

1.单个文档的插入

单个文档的插入,可以使用insert() 或者 save() 方法。二者是等价的。

insert的三个参数:

  • documnet:实际上它的数据结构和JSON基本一样,其所有存储在集合中的数据格式都是BSON格式。类型为:对象或者数组。
  • writeConcern:插入式选择性能的一个级别。类型为数组。
  • ordered:表示插入的数组是否经行排序。 类型为布尔值。

代码示例

利用insert()方法,向comment的集合中插入一条数据,打开cmd窗口,将下列代码在cmd窗口输入,如果出现“nInserted”:1,表示插入数据成功。

tips: (1)如果没有创建comment集合,会自动隐式创建的。

db.collection.insert(

<document or array of documents>,

{

writeConcern: <document>,

ordered: <boolean>

}

)

2.批量文档的插入

批量文档的插入可以使用insertMany(),操作与上面单个文档的插入相似。


代码示例

db.collection.insertMany(

[ <document 1> , <document 2>, ... ],

{

writeConcern: <document>,

ordered: <boolean>

}

)

批量插入的时候,数据较多容易产生失误,所以可以使用我们熟悉的try-catch操作

代码示例

try {
db.comment.insertMany([
{"_id":"1","articleid":"100001","content":"我们不应该把清晨浪费在手机上,健康很重要,一杯温水幸福你我
他。","userid":"1002","nickname":"相忘于江湖","createdatetime":new Date("2019-08-
05T22:08:15.522Z"),"likenum":NumberInt(1000),"state":"1"},
{"_id":"2","articleid":"100001","content":"我夏天空腹喝凉开水,冬天喝温开水","userid":"1005","nickname":"伊人憔
悴","createdatetime":new Date("2019-08-05T23:58:51.485Z"),"likenum":NumberInt(888),"state":"1"},
{"_id":"3","articleid":"100001","content":"我一直喝凉开水,冬天夏天都喝。","userid":"1004","nickname":"杰克船
长","createdatetime":new Date("2019-08-06T01:05:06.321Z"),"likenum":NumberInt(666),"state":"1"},
{"_id":"4","articleid":"100001","content":"专家说不能空腹吃饭,影响健康。","userid":"1003","nickname":"凯
撒","createdatetime":new Date("2019-08-06T08:18:35.288Z"),"likenum":NumberInt(2000),"state":"1"},
{"_id":"5","articleid":"100001","content":"研究表明,刚烧开的水千万不能喝,因为烫
嘴。","userid":"1003","nickname":"凯撒","createdatetime":new Date("2019-08-
06T11:01:02.521Z"),"likenum":NumberInt(3000),"state":"1"}
]);
} catch (e) {
print (e);
}

二.文档的查询

1.基本的查询

查询一个集合里所有的文档,我们可以使用以下命令。

db.comment.find()
db.comment.find({})

如果想按指定定条件来查询,只需要在find()里面添加相应的参数即可实现。注意参数也是json格式的哦。

查询用户编号为1003的记录,(只会返回第一条userid为1003的数据哦):

db.comment.find({userid:'1003'})

2.投影查询

如果只想要查询部分的字段,则使用投影查询,这样就可以只显示指定的字段。

代码示例:查询userid

注意:_ id是会默认显示的,所以如果要不显示_id,要在后面加上_id:0

>db.comment.find({userid:"1003"},{userid:1,_id:0})

{ "userid" : "1003" }

{ "userid" : "1003" }

代码示例:查询所有的数据,但是只显示username和userid以及_id。

>db.comment.find({},{userid:1,nickname:1})

三.文档的更新

文档更新的方法update()

示例代码

db.collection.update(query,update,options)

//或

db.collection.update(

 <query>,

 <update>,

 {

  upsert:<boolean>,

  multi:<boolean>,

  writeConcern:<document>,

  collation:<document>,

  arrayFilters:[<filterdocument1>,...],

  hint: <document|string>    //AvailablestartinginMongoDB4.2

 }

)

update的四个主要参数:

  • query: 更新的条件。可以使用与find()方法中相同的查询选择器,类似sql update查询内where后面的。
  • update:查询的条件
  • upsert:如果设置为true,则在没有与查询条件匹配的文档时创建新文档。默认值为false,如果找不到匹配项,则不会插入新文档
  • multi:可选。如果设置为true,则更新符合查询条件的多个文档。如果设置为false,则更新一个文档。默认值为false。

1.覆盖的修改

代码示例:将_id:1的记录,将username修改为小A

db.comment.update({_id:1},{username:'小A'})

输入一下代码,再查询这个集合时,会发现_id:1的记录就只剩username:'小A',其他的记录全都被覆盖掉了。所以就有下面的操作,局部的修改。

2.局部的修改

局部的修改,我们用 $set运算符来实现

代码示例

将_id:2的记录,username改为‘小B’,这样就可以将username修改,并且不会将其他的数据给完全覆盖掉。

db.comment.update({_id:2},{$set{username:'小B'}})

3.批量的修改

批量的修改其实就是将一个参数修改一下

代码示例

将所有的userid为'1003'的用户名改为‘小明’

db.comment.update({userid:"1003"},{$set{username:'小明'}})

如上代码会默认只修改第一条数据,如下代码会更新所有符合条件的数据

db.comment.update({userid:""1003},{$set{username:'小明'}},{multi:true})

不添加最后的 {multi:true},默认就是更新第一条数据

4.列值增长的修改

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

代码示例

对三号数据的点赞数+1

db.comment.update({_id:"3"},{$inc{likenum:NumberInt(1)}})

四.删除文档

删除文档的方法:remove()

db.集合名称.remove(条件)

将所有的数据都删除(慎用)

db.comment.remove({})

五.文档的分页查询

1.统计查询

统计查询我们使用的不再是find(),而是 count()方法

db.collecation.count(query,options)

count的两个参数

  • query:查询的选择条件
  • options:可选参数,用于修改除计数的额外条件

代码示例

统计所有的记录数

db.comment.count()

按条件统计记录数,统计userid为1003的记录

db.comment.count({userid:"1003"})

2.分页列表的查询

分页列表的查询中,我们可以使用limit() 方法来读取指定数量的数据,使用skip() 方法来跳过指定数量的数据。

代码示例:

>db.comment.find().limit(number).skip(number)

如果想要查询指定的条数,可以在find()方法后面通过limit()方法来返回指定的条数

代码示例

查询前十条数据(如果默认调用limit()但是并不传递参数时,默认就是调用前20条数据)

db.comment.find().limit(10)

如果想要跳过某些数据时,可以在find()方法后面调用skip()方法来跳过指定的条数

代码示例: 跳过指定的前两条数据

db.comment.find().skip(2)

3.排序查询

排序查询我们这里使用sort()方法,sort()可以通过参数指定排序的字段,并使用1和-1来指定排序的方式,其中1表示升序排序-1表示降序排序。

代码示例

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

db.comment.find().sort({userid:-1,likenum:1})

注意

如果sort (),limit(),skip()三个方法同时调用时,执行的顺序是sort(),limit(),skip(),这和命令的编写顺序是无关的。

小结

常用命令(包含了一些其他的查询方法哦)

2023-04-01.png