MongoDB 简介
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
MongoDB 安装
windows
https://www.mongodb.com/try/download/community
选择你喜欢的版本,或者直接用我选好的
https://fastdl.mongodb.org/wi...
使用 curl 下载文件
curl https://fastdl.mongodb.org/win32/mongodb-win32-x86_64-2008plus-3.2.22-signed.msi -o mongodb-win32-x86_64-2008plus-3.2.22-signed.msi
下载完成之后,就可以无脑下一步了(windows就是这么简单)。当然我们还是要选择一下安装目录的
- 打开我们的 msi 文件,下一步,同意协议
- 作为开发我们要定制一下 custom ,选择一下安装路径
- 然后下一步等安装完成吧。
D:\create\mongodb\bin\mongod --dbpath E:\study\mongodb\db
找到我们程序,指定一个数据存储位置,开启我们的服务。(懒得配置 path 环境变量了)
D:\create\mongodb\bin\mongo
进入交互式环境。这里是一个JavaScript shell
linux
还是上面那个地址,选择一个合适的包。然后就是疯狂敲命令
# 下载 wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.2.22.tgz # 解压 tar -zxvf mongodb-linux-x86_64-3.2.22.tgz # 移动到指定位置 mv mongodb-linux-x86_64-3.2.22.tgz /usr/local/mongodb3 # 添加环境变量,也可以用软连接 export PATH=/usr/local/mongodb3/bin:$PATH # 数据存储目录 mkdir -p /var/lib/mongo # 日志目录 mkdir -p /var/log/mongodb # 启动服务 mongod --dbpath /var/lib/mongo --logpath /var/log/mongodb/mongod.log --fork # 常用命令 mongo db # 查看当前数据库对象或集合 show dbs # 显示所有数据库 use face_ai # 切换到对应的数据库 show collections # 显示所有的表 db.db_446a5305d94e2e9cbc7b6b00d7888e0d_login.find().limit(10).skip(80) # 查询表,10条,从80位置开始
概念解析
mysql的术语(SQL) | MongoDB的术语 | 解释 |
database | database | 数据库 |
table(表) | collection(集合) | 用来存放一些相似的数据,比如说存放所有用户信息 |
row(记录) | document(文档) | 用来表示一个物体对象,比如说一个人的信息 |
column(字段) | field(域) | 用来表示物体信息的特征,比如说人的年龄 |
index | index | 索引 |
table joins | 无 | 连表 |
primary key | primary key | 主键 |
Mysqld/Oracle | mongod | 数据库服务 |
mysql/sqlplus | mongo | 客户端 |
可以存在多个数据库,每个数据库中可以包含多个表,每个表可以包含很多条记录,每条记录可以有很多字段。
MongoDB 数据库
show dbs
命令可以显示所有数据库。
数据库也通过名字来标识。数据库名可以是满足以下条件的任意UTF-8字符串。
- 不能是空字符串("")。
- 不得含有' '(空格)、.、$、/、和0 (空字符)。
- 应全部小写。
- 最多64字节。
有一些数据库名是保留的,可以直接访问这些有特殊作用的数据库。
- admin: 从权限的角度来看,这是"root"数据库。要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限。一些特定的服务器端命令也只能从这个数据库运行,比如列出所有的数据库或者关闭服务器。
- local: 这个数据永远不会被复制,可以用来存储限于本地单台服务器的任意集合
- config: 当Mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。
MongoDB 集合
文档是一组键值(key-value)对(即 BSON)。 MongoDB 的文档不需要设置相同的字段,并且相同的字段不需要相同的数据类型,这与关系型数据库有很大的区别,也是 MongoDB 非常突出的特点。
需要注意的是:
- 文档中的键/值对是有序的。
- 文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个嵌入的文档)。
- MongoDB区分类型和大小写。
- MongoDB的文档不能有重复的键。
- 文档的键是字符串。除了少数例外情况,键可以使用任意UTF-8字符。
文档键命名规范:
- 键不能含有0 (空字符)。这个字符用来表示键的结尾。
- .和$有特别的意义,只有在特定环境下才能使用。
- 以下划线"_"开头的键是保留的(不是严格要求的)。
MongoDB 文档
集合就是 MongoDB 文档组,类似于 RDBMS (关系数据库管理系统:Relational Database Management System)中的表格。
集合存在于数据库中,集合没有固定的结构,这意味着你在对集合可以插入不同格式和类型的数据,但通常情况下我们插入集合的数据都会有一定的关联性。
当第一个文档插入时,集合就会被创建。
合法的集合名:
- 集合名不能是空字符串""。
- 集合名不能含有0字符(空字符),这个字符表示集合名的结尾。
- 集合名不能以"system."开头,这是为系统集合保留的前缀。
- 用户创建的集合名字不能含有保留字符。有些驱动程序的确支持在集合名里面包含,这是因为某些系统生成的集合中包含该字符。除非你要访问这种系统创建的集合,否则千万不要在名字里出现$。
MongoDB 数据类型
https://www.runoob.com/mongodb/mongodb-databases-documents-collections.html