Mongodb的基本操作

目录

数据库操作

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

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

数据库的删除

集合操作

集合的创建

集合的显示创建

集合的隐式创建

集合的删除

文档操作

文档的插入

单个插入

批量插入

文档基础查询

查询所有

条件查询

投影查询

文档的更新

覆盖修改

局部修改

批量修改

列值增长的修改

文档删除

分页查询

统计查询

分页查询

排序查询

更多查询

正则的复杂条件查询

比较查询

包含查询

条件连接查询

常用命令总结


SQL术语/概念Mongodb术语/概念解释/说明
databasedatabase数据库
tablecollection数据库表/集合
rowdocument数据记录行/文档
columnfiled数据字段/域
indexindex索引
table join表连接,Mongodb不支持
嵌入文档Mongodb通过嵌入式文档来替代多表查询
primary keyprimary key主键,Mongodb自动将_id字段设置为主键

  BSON包括一个特殊类型,表示可能的最大值。shell中没有这个 类型。

数据类型描述举例
字符串UTF-8字符串都可表示为字符串类型的数据{"x" : "foobar"}
对象id对象id是文档的12字节的唯一 ID{"X" :ObjectId() }
布尔值真或者假:true或者false{"x":true}
数组值的集合或者列表可以表示成数组{"x" : ["a", "b", "c"]}
32位整数类型不可用,shell中默认会转换成64位浮点数
64位整数类型不可用。shell中默认会转换成64 位浮点数
64位浮点数shell中的数字就是这一种类型{"x":3.14159,"y":3}
null表示空值或者未定义的对象{"x":null}
undefined文档中也可以使用未定义类型{"x":undefined}
符号shell不支持,shell会将数据库中的符号类型的数据自动转换成字符串
正则表达式文档中可以包含正则表达式,采用JavaScript的正则表达式语法{"x" : /foobar/i}
代码文档中还可以包含JavaScript代码{"x" : function() { /* …… */ }}
二进制数据二进制数据可以由任意字节的串组成,不过shell中无法使用
最大值/最 小值BSON包括一个特殊类型,表示可能的最大值。shell中没有这个 类型。

数据库操作

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

use 数据库名称

如果数据库不存在则自动创建,并且使用这个数据库。例如,以下语句创建articledb数据库:

use articledb

查看有权限查看的所有的数据库命令

show dbs

show databases

注意: 在 MongoDB 中,数据库只有在创建了一个集合之后才会真正的创建。在此之前,数据库存储在内存中,只有在数据库中添加了集合,才会把数据库添加到磁盘中。

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

db

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

另外:

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

  • 不能是空字符串("")。
  • 不得含有' '(空格)、.、$、/、\和\0 (空字符)
  • 应全部小写
  • 最多64字节。

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

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

数据库的删除

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

db.dropDatabase()

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

集合操作

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

集合的创建

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

集合的显示创建

基本语法格式:

db.createCollection(name)

参数说明:

  • name: 要创建的集合名称

查看当前库中的表:

show tables

集合的命名规范:

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

集合的隐式创建

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

集合的删除

集合删除语法格式如下:

db.集合名称.drop()

返回值

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

文档操作

文档(document)的数据结构和 JSON 基本一样。 所有存储在集合中的数据都是 BSON 格式。

BSON格式指的是二进制形式的JSON,在使用者对文档进行操作的时候使用JSON进行操作。

文档的插入

单个插入

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

db.collection.insertOne(

        <document or array of ducument>,

     {

        writeConcern: <document>,

        ordered: <boolean>

     }

)

参数:

参数类型描述
documentdocument or array要插入到集合中的文档或文档数组(JSON格式)
writeConcerndocument可选的。表达书面关注的文件。省略使用默认的写关注点。如果在事务中运行,则不要显式设置操作的写关注点.
orderedboolean可选。如果为true,则按顺序插入数组中的文档,如果其中一个文档出现错误,Mongodb将返回而不处理数组中的其余文档。如果为false,则执行无序插入,如果其中一个文档出现错误,则继续处理数组中的其余文档。默认为true

例子:

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

db.comment.insertOne(

        {

                "articleid":"100000","content":"今天天气真好,阳光明媚",

                "userid":"1001",

                "nickname":"Rose",

                "createdatetime":new Date(),

                "likenum":NumberInt(10),

                "state":null

        }

)

提示:

  • comment集合如果不存在,则会隐式创建
  • mongo中的数字,默认情况下是double类型,如果要存整型,必须使用函数NumberInt(整型数字),否则取出来就有问题了。
  • 插入当前日期使用 new Date()
  • 插入的数据没有指定 _id ,会自动生成主键值
  • 如果某字段没值,可以赋值为null,或不写该字段。

注意:

  • 文档中的键/值对是有序的。
  • 文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个嵌入的文档)。
  • MongoDB区分类型和大小写。 4
  • MongoDB的文档不能有重复的键。
  • 文档的键是字符串。除了少数例外情况,键可以使用任意UTF-8字符。

文档键命名规范:

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

批量插入

语法:

db.collection.insertMany(

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

        {

                writeConcern:<document>,

                ordered:<boolean>

        }

)

示例:

批量插入多条文章评论:

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"}

 ]

);

提示:

  • 插入时指定了 _id ,则主键就是该值。
  • 如果某条数据插入失败,将会终止插入,但已经插入成功的数据不会回滚掉。
  • 因为批量插入由于数据较多容易出现失败,因此,可以使用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);
}

文档基础查询

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

db.collection.find(<query>, [projection])

参数:

参数类型描述
querydocument可选。使用查询运算符指定选择筛选器。若要放回集合中的所有文档,请省略此参数或传递空文档
projectiondocument可选。指定要在于查询筛选器匹配的文档中返回的字段(投影)。若要返回匹配文档中的所有字段,请省略此参数

查询所有

如果我们要查询集合的所有文档,我们输入以下命令

db.comment.find()

db.comment.find({})

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

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

条件查询

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

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

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

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

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

投影查询

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

如:查询用户编号是1003的记录,返回结果只显示 _id、userid、nickname :

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

默认 _id 会显示。

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

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

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

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

文档的更新

更新文档的语法:

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

db.collection.update(

<query>,

<update>,

{

        upsert:<boolean> ,

        multi:<boolean> ,

        writeConcern: <document>,

        collation: <document>,

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

        hint: <document | string>

}

)

参数:

参数描述
<query>查询条件,指定要更新的文档。符合此查询条件的文档将被更新。如果未指定,则将更新集合中的所有文档。
<update>更新操作,指定要对匹配到的文档执行的更新操作。可以是一个文档,也可以是一系列更新操作符的组合,如 $set$unset 等。
upsert一个布尔值,表示如果查询条件未找到匹配的文档时,是否插入新文档。默认为 false,即不插入新文档。
multi一个布尔值,表示是否更新多个匹配到的文档。默认为 false,即只更新第一个匹配到的文档。
writeConcern一个文档,指定写入操作的确认级别。可以指定 w(确认写入的副本数量)、wtimeout(写入操作超时时间)等参数。
collation一个文档,指定比较字符串时的排序规则。可以包含 locale(语言环境)、caseLevel(是否区分大小写)等参数。
arrayFilters一个数组,用于指定更新数组字段时的过滤条件。可以在更新操作中引用这些过滤条件。
hint一个文档或字符串,指定在更新操作中使用的索引。可以是索引键的值或索引的名称。

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

覆盖修改

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

db.comment.replaceOne({_id:"1"},{likenum:NumberInt(1002)})

 

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

局部修改

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

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

db.comment.update({_id:"2"},{$set:{likenum:NumberInt(889)}})

这样在修改的时候就只会修改指定的部分。

批量修改

更新所有用户为 1003 的用户的昵称为 凯撒大帝

//默认只修改第一条数据

db.comment.update({userid:"1003"},{$set:{nickname:"凯撒2"}})

//修改所有符合条件的数据

db.comment.update({userid:"1003"},{$set:{nickname:"凯撒大帝"}},{multi:true})

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

列值增长的修改

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

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

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

文档删除

删除文档的语法结构:

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

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

db.集合名称.remove({})

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

db.comment.deleteOne({_id:"1"})

分页查询

统计查询

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

db.collection.count(query, options)

参数

参数类型描述
querydocument查询选择条件
optionsdocument可选。用于修改计数的额外选项

示例:

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

db.comment.count()

不过可以看到最新的Mongodb以及不建议我们使用count()了

使用它建议的方法

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

 

分页查询

可以使用limit()方法来读取指定数量的数据,使用skip()方法来跳过指定数量的数据。 基本语法如下所示:

db.集合名称.find().limit(数量).skip(数量)

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

db.comment.find().limit(3) //只返回前面的3条数据

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

db.comment.find().skip(3) //跳过前面的3条数据

分页查询:

需求:每页只显示2条数据

//第一页

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

//第二页

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

//第三页

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

排序查询

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

语法如下所示:

db.集合名称.find().sort({KEY:1})

db.集合名称.find().sort(排序方式)

例如:

按照likenum进行升序排序

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

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

更多查询

正则的复杂条件查询

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

db.collection.find({field:/正则表达式/})

db.集合.find({字段:/正则表达式/})

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

例如,我要查询评论内容包含“开水”的所有文档,代码如下:

db.comment.find({content:/开水/})

如果要查询评论的内容中以“专家”开头的,代码如下: 

db.comment.find({content:/^专家/})

比较查询

使用<,<=,>, >=,!= 这些操作符进行比较查询,格式如下:

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的记录

db.comment.find({likenum:{$lt:700}})

包含查询

包含查询使用 "$in" 操作符。

示例:查询评论的集合中userid字段包含1003或1004的文档

db.comment.find({userid:{$in:["1003","1004"]}})

不包含查询使用 "$nin" 操作符。

示例:查询评论集合中userid字段不包含1003和1004的文档

db.comment.find({userid:{$nin:["1003","1004"]}})

条件连接查询

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

格式为:

$and:[ { },{ },{ } ]

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

db.comment.find({$and:[{likenum:{$gte:NumberInt(700)}},{likenum:{$lt:NumberInt(2000)}}]})

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

$or:[ { },{ },{ } ]

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

db.comment.find({$or:[ {userid:"1003"} ,{likenum:{$lt:1000} }]})

常用命令总结

选择切换数据库: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.replaceOne({条件},{修改后的数据}) 或  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}]})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值