MongoDB 学习笔记

MongoDB
MongoDB

MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。

安装

官网下载地址

https://www.mongodb.com/download-center#community

windows 版安装

  1. 选择对应的版本下载预编译二进制包即可

Ⅰ. 在 MongoDB 2.2 版本后已经不再支持 Windows XP 系统。最新版本也已经没有了 32 位系统的安装文件。
Ⅱ. 在 Choose Setup Type 时选择 Custom 可指定安装目录
Ⅲ. MongoDB Compass 是 MongoDB 可视化管理工具,可选择是否安装
Ⅳ. 安装后在系统环境变量中添加 MongDB 安装目录下的 bin 目录

  1. 创建数据目录
    MongoDB 将数据目录存储在 db 目录下,但db 目录不会自动创建需要手动创建
cd e:/
mkdir MongoDB
cd MongoDB
mkdir db
  1. 命令行启动 MongoDB 服务
    命令行执行 mongod --dbpath e:/MongoDB/db 启动服务;
    另一命令行执行 mongo 即可连接该服务,不指定地址和端口默认尝试连接localhost 的 27017 端口。

Linux 版安装

  1. 根据系统版本下载对应版本的压缩包,解压即可
  2. MongoDB 的可执行文件位于 bin 目录下,所以可以将其添加到 PATH 路径中(类似 windows 系统添加到环境变量)
export PATH=MongoDB 安装目录/bin:$PATH

常用命令

show dbs; 查看所有数据库;
show users; 查看用户;
db 查看当前数据库;
use 指定要使用的数据库,数据库不存在则创建,并且插入数据后才会显示;
db.dropDatabase 删除数据库;
db.createCollection 创建集合,集合不需要手动创建,插入数据时会自动创建;
show collections 显示集合列表;
db.COLLECTION_NAME.drop() 删除集合;
db.COLLECTION_NAME.insert(document) 插入数据
db.COLLECTION_NAME.save(document) 不指定_id 时插入数据同 insert ,指定时更新数据;
db.version() 查看数据库版本;
db.cloneDatabase("127.0.0.1") 将指定机器上的数据库的数据克隆到当前数据;
db.copyDatabase("mydb", "temp", "127.0.0.1") 将本机的mydb的数据复制到temp数据库中;

用户管理

  • MongoDB 没有默认管理员用户,所以要先添加管理员用户,再开启权限认证;
  • 切换到 admin 数据库,添加的账号才是管理员用户;
  • 用户只能在用户所在数据库登录,包括管理员用户;
  • 管理员可以管理所有数据库,但是不能直接管理其他数据库,要先在 admin 数据库认证后才可以。

添加管理员用户

  1. 连接数据库 --> mongomongo --host=127.0.0.1 --port=27017 ;
  2. 切换到 admin 库 --> use admin;
  3. 插入 admin 用户
db.createUser(
   {
     user: "admin",//用户名
     pwd: "admin",//密码
     roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
   }
)

输入输出示例:

C:\Users\tal>mongo
MongoDB shell version v3.6.5
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.6.5
//省略 warning 日志
> use admin;
switched to db admin
> show collections;
system.version
> db.createUser({"user":"admin","pwd":"admin","roles":[{"role":"userAdminAnyDatabase","db":"admin"}]})
Successfully added user: {
        "user" : "admin",
        "roles" : [
                {
                        "role" : "userAdminAnyDatabase",
                        "db" : "admin"
                }
        ]
}
> show users;
{
        "_id" : "admin.admin",
        "user" : "admin",
        "db" : "admin",
        "roles" : [
                {
                        "role" : "userAdminAnyDatabase",
                        "db" : "admin"
                }
        ]
}

开启权限认证

a. 权限认证方式启动服务

  • 新建 MongoDB 配置文件 e:/MongoDB/MongoDB.conf
  • 向配置文件添加配置
dbpath = e:/MongoDB/db  # 指定dbpath ,需要手动创建文件夹
logpath = e:/MongoDB/logs/MongoDB.log  # 指定日志输出路径,需手动创建文件
logappend =  # 制定日志是追加
journal = # 表示启动日志
auth = true # 指定开启权限认证
  • 使用配置文件启动方式启动服务 mongod -f e:/MongoDB/MongoDB.confmongod --config e:/MongoDB/MongoDB.conf

b. 用户验证

  • mongo 连接数据库;
  • show dbs; 会有 "Unauthorized" 错误,说明权限认证已开启;
  • use admin 切换到 admin 库,db.auth('admin','admin') 用户授权,授权成功 显示 1 ,失败显示 0 和错误信息;

添加普通数据库用户

  1. admin 库管理登陆;
  2. 切换到业务数据库 use demo; , demo是数据库名;
  3. 创建用户 db.createUser({"user":"demoUser","pwd":"demoUser","roles":[{"role":"readWrite","db":"demo"}]});
  4. 使用新建的用户登陆对应的数据库即可。

数据库角色

角色类型 角色名称
数据库用户角色 read、readWrite;
数据库管理角色 dbAdmin、dbOwner、userAdmin;
集群管理角色 clusterAdmin、clusterManager、clusterMonitor、hostManager;
备份恢复角色 backup、restore;
所有数据库角色 readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
超级用户角色 root #这里还有几个角色间接或直接提供了系统超级用户的访问(dbOwner 、userAdmin、userAdminAnyDatabase)
内部角色 __system
角色名称 角色说明
Read 允许用户读取指定数据库
readWrite 允许用户读写指定数据库
dbAdmin 允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile
userAdmin 允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户
dbOwner 具有 readWrite、dbAdmin、userAdmin 角色的权限
clusterAdmin 只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。
readAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的读权限
readWriteAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的读写权限
userAdminAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的userAdmin权限
dbAdminAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。
root 只在admin数据库中可用。超级账号,超级权限

创建数据库

MongoDB 没有创建数据库的命令,use 数据库名 后创建集合 db.createCollection('集合名') 或插入数据 db.COLLECTION_NAME.insert('文档') 即可新建数据库(集合本身不需要创建,插入数据会自动创建)。

ps:

  1. Mongdb shell 是 javascripte 环境,语句结束符;可省略;
  2. 数据库名全小写,最多64字节,不能是空字符串(""),不得含有' '(空格)、.、$、/、\和\0 (空字符);

集合操作

创建集合

MongoDB 一般不需要显式创建集合,插入文档时会自动创建。需要创建特殊属性的集合时需要手动创建。
集合创建命令:db.createCollection(name, options) name --> 数据库名;options --> 数据库属性。

options 可选属性:

字段 类型 说明
capped boolean (可选)是否为固定集合。固定集合是指有着固定大小的集合,当达到最大值时,它会自动覆盖最早的文档。默认为false;当该值为 true 时,必须指定 size 参数。
autoIndexId boolean (可选)是否自动在 _id 字段创建索引。默认为 false。
size 数值 (可选)为固定集合指定一个最大值(字节)。
max 数值 (可选)指定固定集合中包含文档的最大数量。

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

删除集合

集合删除命令:

db.collectionName.drop() # collectionName 指集合名称

成功删除返回 true ,删除失败返回 false

文档操作

插入文档

  • 插入文档:db.collectionName.insert(document);
  • db.collectionName.save(document),若 document 不指定 _id ,则执行插入操作;
  • 3.2 版本后,新增两种插入方式
db.collectionName.insertOne(document)  # 向指定集合中插入一条文档数据
db.collectionName.insertMany([document,...])  # 向指定集合中插入多条文档数据

更新文档

  • update()方法更新文档,语法格式:
db.collectionName.update(
   <query>,
   <update>,
   {
     upsert: <boolean>,
     multi: <boolean>,
     writeConcern: <document>
   }
)
参数 解释
query 查询条件,类似 sql 的 where 语句
update 更新对象和一些操作符(如$,$inc...),类似 sql 的 set 语句
upsert 可选,不存在记录时是否插入,默认 false
multi 可选,是否更新所有符合条件的记录,默认 false 只更新第一条
writeConcern 可选,抛出异常的级别
  • save()方法更新文档,语法格式:
db.collectionName.save(document)

根据 document 的 _id 替换文档

  • 3.2 版本后,新增两种更新方式
// 更新单个文档,类似 update() multi 参数为 false
db.collectionName.updateOne() 
// 更新多个文档,类似 update() multi 参数为 true
db.collectionName.updateMany() 向指定集合更新多个文档

删除文档

  • remove() 删除文档(已废弃),语法
db.collectionName.remove(
   <query>,// 删除条件
   {
     justOne: <boolean>,// 为 true 或 1 时只删除一个文档
     writeConcern: <document>
   }
)
  • 推荐的删除方法
// 删除符合条件的第一条文档
db.collectionName.deleteOne( query )
// 删除符合条件的所有文档
db.collectionName.deleteMany( query )
  • 清空集合 db.collectionName.deleteMany({})
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容