一.文档的插入
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(),这和命令的编写顺序是无关的。
小结
常用命令(包含了一些其他的查询方法哦)