MongoDB学习(三)

前言

一、安装 MongoDB

二、MongoDB 概念解析

三、 MongoDB 数据类型

四、MongoDB 数据库操作

五、MongoDB 集合操作

六、文档操作

总结






前言

上一篇介绍了MongoDB的原理,这一篇将要开始Mongodb的基础学习。






一、安装 MongoDB

官方安装

Install MongoDB Community Edition — MongoDB Manual

我的电脑是Ubuntu20.04 ,参考下面安装过程

Install MongoDB Community on Ubuntu using .tgz Tarball — MongoDB Manual

创建数据目录:mkdir --p  /var/lib/mongo

创建log目录:mkdir --p  var/log/mongodb

启动mongodb: mongod --dbpath=/var/lib/mongo --logpath /var/log/mongodb/mongod.log --fork

输入mongo 进入命令行

huangbingbing@huangbingbing-Shangqi-X4270:~/mongodata$ mongo
MongoDB shell version v5.0.5
connecting to: mongodb://127.0.0.1:27017/?compressors=disabled&gssapiServiceName=mongodb
Implicit session: session { "id" : UUID("4dd5b970-1751-42aa-90b3-68b59673bcf1") }
MongoDB server version: 5.0.5
================
Warning: the "mongo" shell has been superseded by "mongosh",
which delivers improved usability and compatibility.The "mongo" shell has been deprecated and will be removed in
an upcoming release.
For installation instructions, see
https://docs.mongodb.com/mongodb-shell/install/
================
---
The server generated these startup warnings when booting: 
        2021-12-26T23:17:50.862+08:00: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine. See http://dochub.mongodb.org/core/prodnotes-filesystem
        2021-12-26T23:17:51.485+08:00: Access control is not enabled for the database. Read and write access to data and configuration is unrestricted
        2021-12-26T23:17:51.485+08:00: This server is bound to localhost. Remote systems will be unable to connect to this server. Start the server with --bind_ip <address> to specify which IP addresses it should serve responses from, or with --bind_ip_all to bind to all interfaces. If this behavior is desired, start the server with --bind_ip 127.0.0.1 to disable this warning
        2021-12-26T23:17:51.485+08:00: Soft rlimits for open file descriptors too low
        2021-12-26T23:17:51.485+08:00:         currentValue: 1024
        2021-12-26T23:17:51.485+08:00:         recommendedMinimum: 64000
---
---
        Enable MongoDB's free cloud-based monitoring service, which will then receive and display
        metrics about your deployment (disk utilization, CPU, operation statistics, etc).

        The monitoring data will be available on a MongoDB website with a unique URL accessible to you
        and anyone you share the URL with. MongoDB may use this information to make product
        improvements and to suggest MongoDB products and deployment options to you.

        To enable free monitoring, run the following command: db.enableFreeMonitoring()
        To permanently disable this reminder, run the following command: db.disableFreeMonitoring()
---





二、MongoDB 概念解析

层次结构

实例:系统上运行的进程及节点集,一个实例可以有多个库,默认端口 27017。

库:多个集合组成数据库,每个数据库都是独立的,有自己的用户、权限信息,独立的存储文件集 合。

集合:即是一组文档的集合,集合内的文档结构可以不同。

文档:MongoDB 的最小数据单元,其基本概念为:多个键值对有序组合在一起的数据单元。

db.users.insert({"name":"test","age":23})

与关系型数据库的对比

 概念对比

基本概念

1.数据库

一个 mongodb 中可以建立多个数据库。MongoDB 的默认数据库为"db",该数据库存储在 data 目录 中。MongoDB 的单个实例可以容纳多个独立的数据库,每一个都有自己的集合和权限,不同的数据 库也放置在不同的文件中。

"show dbs" 命令可以显示所有数据的列表。

> show dbs
admin   0.000GB
config  0.000GB
local   0.000GB
test    0.000GB

执行 "db" 命令可以显示当前数据库对象或集合。

> db;
test

运行"use"命令,可以连接到一个指定的数据库。

> use test
switched to db test

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

admin: 从权限的角度来看,这是"root"数据库。要是将一个用户添加到这个数据库,这个用户 自动继承所有数据库的权限。一些特定的服务器端命令也只能从这个数据库运行,比如列出所 有的数据库或者关闭服务器。

 local: 这个数据永远不会被复制,可以用来存储限于本地单台服务器的任意集合

config: 当 Mongo 用于分片设置时,config 数据库在内部使用,用于保存分片的相关信息。

2.文档

文档是一组键值(key-value)对(即 BSON)。MongoDB 的文档不需要设置相同的字段,并且相同的字段 不需要相同的数据类型,这与关系型数据库有很大的区别,也是 MongoDB 非常突出的特点。例如{"name":"test","age":23}

需要注意的是:

        文档中的键/值对是有序的。

        文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个 嵌入的文档)。

         MongoDB 区分类型和大小写。

        MongoDB 的文档不能有重复的键。

        文档的键是字符串。除了少数例外情况,键可以使用任意 UTF-8 字符。

        文档对应于许多编程语言中的本机数据类型

        嵌入式文档和数组减少了对连接的需求

        动态模式支持流畅的多态性

文档键命名规范:

        键不能含有\0 (空字符)。这个字符用来表示键的结尾。

         .和$有特别的意义,只有在特定环境下才能使用。

        以下划线"_"开头的键是保留的(不是严格要求的)。

3.集合

集合就是 MongoDB 文档组,类似于 RDBMS (关系数据库管理系统:Relational Database Management System)中的表格。 集合存在于数据库中,集合没有固定的结构,这意味着你在对集合可以插入不同格式和类型的数据, 但通常情况下我们插入集合的数据都会有一定的关联性。

db.users.insert({"name":"test","age":23})

当第一个文档插入时,集合就会被创建。

合法的集合名

        集合名不能是空字符串""。

        集合名不能含有\0 字符(空字符),这个字符表示集合名的结尾。

        集合名不能以"system."开头,这是为系统集合保留的前缀。

        用户创建的集合名字不能含有保留字符。有些驱动程序的确支持在集合名里面包含,这是因为 某些系统生成的集合中包含该字符。除非你要访问这种系统创建的集合,否则千万不要在名字 里出现$。 如下实例:

> db.users.findOne();
{
    "_id" : ObjectId("61c88de3ae32bf3e7301d743"),
    "name" : "test",
    "age" : 23
}
4.固定集合 capped collections

         Capped collections 就是固定大小的 collection。它有很高的性能以及队列过期的特性(过期按照插入的 顺序). 有点和 "RRD" 概念类似。Capped collections 是高性能自动的维护对象的插入顺序。它非常适 合类似记录日志的功能和标准的 collection 不同,你必须要显式的创建一个 capped collection,指定 一个 collection 的大小,单位是字节。collection 的数据存储空间值提前分配的。Capped collections 可以按照文档的插入顺序保存到集合中,而且这些文档在磁盘上存放位置也是按照插入顺序来保存 的,所以当我们更新 Capped collections 中文档的时候,更新后的文档不可以超过之前文档的大小, 这样话就可以确保所有文档在磁盘上的位置一直保持不变。由于 Capped collection 是按照文档的插 入顺序而不是使用索引确定插入位置,这样的话可以提高增添数据的效率。MongoDB 的操作日志文 件 oplog.rs 就是利用 Capped Collection 来实现的。要注意的是指定的存储大小包含了数据库的头信 息。

> db.createCollection("fixCollection", {capped:true,size:10000});
{ "ok" : 1 }

在 capped collection 中,你能添加新的对象。

能进行更新,然而,对象不会增加存储空间。如果增加,更新就会失败 。

使用 Capped Collection 不能删除一个文档,可以使用 drop() 方法删除 collection 所有的行。

删除之后,你必须显式的重新创建这个 collection。

在 32bit 机器中,capped collection 最大存储为 1e9( 1X109 )个字节。

固定集合可以声明 collection 的容量大小,其行为类似于循环队列。数据插入时,新文档会被插入到 队列的末尾,如果队列已经被占满,那么最老的文档会被之后插入的文档覆盖。

固定集合特性:固定集合很像环形队列,如果空间不足,最早的文档就会被删除,为新的文档腾出 空间。一般来说,固定集合适用于任何想要自动淘汰过期属性的场景。

固定集合应用场景

比如日志文件,聊天记录,通话信息记录等只需保留最近某段时间内的应用场景,都会使用到 MongoDB 的固定集合。

固定集合的优点

        写入速度提升。固定集合中的数据被顺序写入磁盘上的固定空间,所以,不会因为其他集合的一 些随机性的写操作而“中断”,其写入速度非常快(不建立索引,性能更好)。

         固定集合会自动覆盖掉最老的文档,因此不需要再配置额外的工作来进行旧文档删除。设置 Job 进行旧文档的定时删除容易形成性能的压力毛刺。 固定集合非常适合用于记录日志等场景。

固定集合的创建 不同于普通集合,固定集合必须在使用前显式创建。 例如,创建固定集合 test_capped,大小限制为 1024 个字节。 db.createCollection("test_capped",{capped:true,size:1024});

注意事项

(1) 固定集合创建之后就不可以改变,只能将其删除重建。

(2) 普通集合可以使用 convertToCapped 转换固定集合,但是固定集合不可以转换为普通集合。

(3) 创建固定集合,为固定集合指定文档数量限制时(指参数 max),必须同时指定固定集合的大 小(指参数 size)。不管先达到哪一个限制,之后插入的新文档都会把最老的文档移除集合。 (4) 使用 convertToCapped 命令将普通集合转换固定集合时,既有的索引会丢失,需要手动创建。并且,此转换命令没有限制文档数量的参数(即没有 max 的参数选项)。

(5) 不可以对 固定集合 进行分片。

(6) 对固定集合中的文档可以进行更新(update)操作,但更新不能导致文档的 Size 增长或缩小,否 则更新失败。 假如集合中有一个 key,其 value 对应的数据长度为 100 个字节,如果要更新这个 key 对应的 value, 更新后的值也必须为 100 个字节,大于 100 个字节不可以,小于 100 个字节也不可以。 报错信息为:Cannot change the size of a document in a capped collection : XXXX(XXXX 代表某个数据 字) !=XXXX。

(7) 不可以对固定集合执行删除文档操作,但可以删除整个集合。 删除文档时,报错信息为:cannot remove from a capped collection:XXXX

(8) 还有一定需要注意,对集合估算 size 时,不要依据集合的 storageSize ,而是依据集合的 size。 storageSize 是 wiredTiger 存储引擎采用高压缩算法压缩后的。

三、 MongoDB 数据类型

数据类型描述
String字符串。存储数据常用的数据类型。在 MongoDB 中,UTF-8 编码的字符 串才是合法的。
Integer整型数值。用于存储数值。根据你所采用的服务器,可分为 32 位或 64 位。
Boolean布尔值。用于存储布尔值(真/假)。
Double双精度浮点值。用于存储浮点值。
Min/Max keys 将一将一个值与 BSON(二进制的 JSON)元素的最低值和最高值相对比。
Array用于将数组或列表或多个值存储为一个键。
Timestamp时间戳。记录文档修改或添加的具体时间。
Object用于内嵌文档。
Null用于创建空值。
Symbol符号。该数据类型基本上等同于字符串类型,但不同的是,它一般用于采用 特殊符号类型的语言。
Date日期时间。用 UNIX 时间格式来存储当前日期或时间。你可以指定自己的 日期时间:创建 Date 对象,传入年月日信息。
Object ID 对对象 ID。用于创建文档的 ID。
Binary Data 二进制数据。用于存储二进制数据。
Code代码类型。用于在文档中存储 JavaScript 代码。
Regular expression正则表达式类型。用于存储正则表达式。

ObjectId

         ObjectId 类似唯一主键,可以很快的去生成和排序,包含 12 bytes,

含义是:

⚫ 前 4 个字节表示创建 unix 时间戳,格林尼治时间 UTC 时间,比北京时间晚了 8 个小时

⚫ 接下来的 3 个字节是机器标识码

⚫ 紧接的两个字节由进程 id 组成 PID

⚫ 最后三个字节是随机数


 MongoDB 中存储的文档必须有一个 _id 键。这个键的值可以是任何类型的,默认是个 ObjectId 对 象,由于 ObjectId 中保存了创建的时间戳,所以你不需要为你的文档保存时间戳字段,你可以通过 getTimestamp 函数来获取文档的创建时间:

> var newObject = ObjectId();
> newObject.getTimestamp();
ISODate("2021-12-26T16:23:25Z")

ObjectId 转为字符串

> newObject.str;
61c896fd0bdd2a5abb9b3d11

字符串

BSON 字符串都是 UTF-8 编码。

时间戳

BSON 有一个特殊的时间戳类型用于 MongoDB 内部使用,与普通的 日期 类型不相关。 时间戳值 是一个 64 位的值。其中:

⚫ 前 32 位是一个 time_t 值(与 Unix 新纪元相差的秒数)

⚫ 后 32 位是在某秒中操作的一个递增的序数

在单个 mongod 实例中,时间戳值通常是唯一的。 在复制集中, oplog 有一个 ts 字段。这个字段中的值使用 BSON 时间戳表示了操作时间。 BSON 时间戳类型主要用于 MongoDB 内部使用。在大多数情况下的应用开发中,你可以使用 B SON 日期类型。

日期

表示当前距离 Unix 新纪元(1970 年 1 月 1 日)的毫秒数。日期类型是有符号的, 负数表示 1970 年 之前的日期。

> var date1 = new Date();
> date1;
ISODate("2021-12-26T16:26:05.516Z")
> typeof date1;
object

这样创建的时间是日期类型,可以使用 JS 中的 Date 类型的方法。 返回一个时间类型的字符串:

> date1.toString();
Mon Dec 27 2021 00:26:05 GMT+0800 (CST)

四、MongoDB 数据库操作

操作命令作用
use DATABASE_NAME如果数据库不存在,则创建数据库,否则切换到指定数据 库。
show dbs查看所有数据库
db显示当前数据库
db.dropDatabase()删除当前数据库

更多命令参考:https://docs.mongodb.com/manual/reference/method/js-database/

MongoDB 创建数据库

use bingbinghuang 如果数据库不存在,则创建数据库,否则切换到指定数据库。

> use bingbinghuang
switched to db bingbinghuang
> db
bingbinghuang

如果你想查看所有数据库,可以使用 show dbs 命令

> show dbs;
admin   0.000GB
config  0.000GB
local   0.000GB
test    0.000GB
bingbinghuang 不在上面,需要插入一条数据

> db.users.insert({"name":"test","age":23});
WriteResult({ "nInserted" : 1 })
> show dbs;
admin          0.000GB
bingbinghuang  0.000GB
config         0.000GB
local          0.000GB
test           0.000GB

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

MongoDB 删除数据库

> db.dropDatabase();
{ "ok" : 1 }

五、MongoDB 集合操作

操作命令作用
db.createCollection创建集合
show collections查看当前库有多少集合
show tables查看当前库有多少集合
db.collection.drop()删除集合
db.collection1.renameCollection( " collection2" )将集合名 collection1 命名为 collection2.

更多参考:https://docs.mongodb.com/manual/reference/method/db.createCollection

MongoDB 创建集合

MongoDB 中使用 createCollection() 方法 来创建集合。

db.createCollection(name, options)

参数说明:

⚫ name: 要创建的集合名称

⚫ options: 可选参数, 指定有关内存大小及索引的选项 options

可以是如下参数:

字段类型描述
capped布尔(可选)如果为 true,则创建固定集合。固定集合是指有着固定大小的集合,当达 到最大值时,它会自动覆盖最早的文档。 当该值为 true 时,必须指定 size 参
size数值(可选)为固定集合指定一个最大值,以千字节计(KB)。 如果 capped 为 true,也需要指定该字段
max数值(可选)指定固定集合中包含文档的最大数量。




 

在插入文档时,MongoDB 首先检查固定集合的 size 字段,然后检查 max 字段。

> db.createCollection("teacher");
{ "ok" : 1 }
> show collections;
student
teacher
users

下面是带有几个关键参数的 createCollection() 的用法: 创建固定集合 col_capped1,整个集合空间大小 6142800 KB, 文档最大个数为 10000 个。

> db.createCollection("col_capped1", {capped: true, size: 6142800, max: 10000});
{ "ok" : 1 }

在 MongoDB 中,你不需要创建集合。当你插入一些文档时,MongoDB 会自动创建集合。
> db.items.insert({"itemId":1,"num":5});
WriteResult({ "nInserted" : 1 })
> show collections;
col_capped
col_capped1
items
student
teacher
users

MongoDB 删除集合

MongoDB 中使用 drop() 方法来删除集合。

db.collection.drop()

参数说明:

⚫ 无 返回值

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

在数据库 bingbinghuang 中,我们可以先通过 show collections 命令查看已存在的集合:
> show collections;
col_capped
col_capped1
items
student
teacher
users
> db.items.drop();
true
> show collections;
col_capped
col_capped1
student
teacher
users
MongoDB 重命名集合
通过 db.student.renameCollection("stu") 重命名集合名。

六、文档操作

        内容较多,放下一篇介绍


总结

        掌握了Mongodb的基础操作。

 技术参考

C/C++Linux服务器开发/后台架构师【零声教育】-学习视频教程-腾讯课堂

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值