作者:云怀大师兄

博客园:https://www.cnblogs.com/yunhuai/

公众号:云怀大师兄

与Mysql概念对比

说明 MySQL MongoDB
数据库 DatatBase DataBase
数据表/集合 Table Collection
数据行/文档 Row Document
字段/域 Column field
索引 Index Index
表连接 Join 不支持,使用内嵌文档
主键 Primary Key Primary Key自动将_id设为主键
服务端 mysqld mongod
客户端 mysql mongo

数据类型

类型 说明
String 字符串,utf-8才是合法字符
Integer 根据服务器而不同,分32位、64位
Boolean 布尔值
Double 如果是数值,默认Double类型
Array 数组
TimeStamp 时间戳
Object 主要用于内嵌文档
Null 用于创造空值
Symbol 特殊符号
Date 日期时间
Min/Max key 将一个元素与Bson的最低值和最高值对比

用户管理

常用权限

权限 说明
read 允许读取(系统级别的集合等不能读取)
readAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的读取权限
readWrite 允许读写
readWriteAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的读写权限
dbAdmin 允许用户在指定数据库中执行管理函数,如索引的创建删除,统计,访问system.profile
dbAdminAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的相应dbAdmin权限
userAdmin 可以管理用户(system.users)
userAdminAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的相应userAdmin权限
ClusterAdmin 只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限
root 只在admin数据库可用,超级管理员账号

创建用户

新增一个账号(user)为root,密码(pwd)为root,权限集合(roles)为:在数据库(db)为admin的库中,赋予其root的权限(role),并为此账号添加相关说明

db.createUser({"user":"root","pwd":"root",roles:[{"role":"root","db":"admin"}],"customData":{"infomation":"First MongoDB User"}})

修改用户

db.updateUser("用户名",{"pwd":"123","roles":["role":"readWriteAnyDatabase","db":"admin"]})

修改用户密码

db.changeUserPassword(""用户名,"新密码")

删除用户

需要权限:userAdmin

db.dropUser("用户名")

数据库管理

查看

show dbs

show databases

创建

use 库名,自动创建,逻辑创建,内存中创建,插入数据后写入硬盘

删除

进哪个库删哪个库

db.dropDatabase()

集合管理(Collection)

创建

db.createCollection('集合名')

向一个不存在的集合插入数据,也可创建,且效果与上一模一样

db.集合名.insert(插入的数据的json)

集合约束

db.createCollection('集合名',{'capped':true,'size':2000,'max':100,'autoIndexId':true})
key 含义
cappend 默认false 容量无限制,如果为true,就说明有限制,那么size 必须有
size 指定大小(字节),会根据设置的自动找最近的2的整数次幂或者2的整数次幂的和,比如写1000会自动变为1024,写500变为512 ,700变为 512+256=768
max 最大个数,新增时先检查容量,再检查个数
autoIndexId 自动主键创建索引,已过期,MongoDB后续会删除

查询

show tables

show collections 查看集合详情:db.集合名.stats()

删除

db.集合名.drop()

MongoDB 基础手册(一)的更多相关文章

  1. mongodb基础用法

    安装部分 mongodb配置方法 mongodb的安装目录 C:\MongoDB\Server\3.2\bin 创建以下目录 c:\mongo\log c:\mongo\db 创建mongodb的配置 ...

  2. mongodb基础系列——数据库查询数据返回前台JSP(一)

    经过一段时间停顿,终于提笔来重新整理mongodb基础系列博客了. 同时也很抱歉,由于各种原因,没有及时整理出,今天做了一个demo,来演示,mongodb数据库查询的数据在JSP显示问题. 做了一个 ...

  3. MongoDB基础知识 02

    MongoDB基础知识 02 6 数据类型 6.1 null : 表示空值或者不存在的字段 {"x":null} 6.2 布尔型 : 布尔类型只有两个值true和false {&q ...

  4. MongoDB基础知识 01

    MongoDB基础知识  1. 文档  文档是MongoDB中的数据的基本单元,类似于关系型数据库管理系统的行. 文档是键值对的一个有序集.通常包含一个或者多个键值对. 例如: {”greeting& ...

  5. MongoDB基础教程系列--未完待续

    最近对 MongoDB 产生兴趣,在网上找的大部分都是 2.X 版本,由于 2.X 与 3.X 差别还是很大的,所以自己参考官网,写了本系列.MongoDB 的知识还是很多的,本系列会持续更新,本文作 ...

  6. DataBase MongoDB基础知识记录

    MongoDB基础知识记录 一.概念: 讲mongdb就必须提一下nosql,因为mongdb是nosql的代表作: NoSQL(Not Only SQL ),意即“不仅仅是SQL” ,指的是非关系型 ...

  7. MongoDB 基础(2019年开篇)

    MongoDB基础知识: 1.什么是MongoDB NoSQL(NoSQL=Not Only SQL),意即"不仅仅是SQL". MongoDB是一个介于关系数据库和非关系数据库之 ...

  8. MongoDB基础学习

    *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...

  9. windows下mongodb基础玩法系列二CURD附加一

    windows下mongodb基础玩法系列 windows下mongodb基础玩法系列一介绍与安装 windows下mongodb基础玩法系列二CURD操作(创建.更新.读取和删除) windows下 ...

随机推荐

  1. Python实现自动整理文件

    前言 工作上的文档和资料好几个月没整理了,因为平常太忙都是随手往桌面丢.整个桌面杂乱无章全是文档和资料.几乎快占满整个屏幕了,所有我必须要整理一下了.但是手动整理太费时间了,于是我想到了python. ...

  2. 【补题记录】NOIp-提高/CSP-S 刷题记录

    Intro 众所周知原题没写过是很吃亏的,突然发现自己许多联赛题未补,故开此坑. 在基本补完前会持续更新,希望在 NOIp2020 前填完. 虽然是"联赛题",但不少题目还是富有思 ...

  3. AcWing 380. 舞动的夜晚

    大型补档计划 题目链接 这题是求必须边,而不是不可行边,因为不可行边 = 必须边 + 死掉了的边(貌似lyd第三版书上还是说的不可行边)先跑最大流. 在跑完以后的残余网络上,对于一条当前匹配的边 \( ...

  4. ACM里的期望和概率问题 从入门到精通

    起因:在2020年一场HDU多校赛上.有这么一题没做出来. 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6829 题目大意:有三个人,他们分别有X,Y ...

  5. 敏捷开发 | DSDM 在非 IT 领域也同样适用?

    动态系统开发方法(Dynamic Systems Development Method:DSDM)是在快速应用程序开发(RAD)方法的基础上改进的.作为敏捷方法论的一种,DSDM方法倡导以业务为核心, ...

  6. MySQL和sparkSQL合并行

    表A 表B 从表A到表B MySQL 写法:select name, group_concat(score seperate ';') as score from A group by name sp ...

  7. vs2015常用快捷键大全

    1.回到上一个光标位置/前进到下一个光标位置 1)回到上一个光标位置:使用组合键"Ctrl + -"; 2)前进到下一个光标位置:"Ctrl + Shift + - &q ...

  8. 面试 23-面试技巧 by smyhvae

    23-面试技巧 by smyhvae #写简历的注意事项 最多可以写"深入了解",但不要写"精通". #遇到不知道的问题,该怎么回答 这块儿我没了解过,准备回去 ...

  9. [日常摸鱼]bzoj4802 欧拉函数-PollardRho大整数分解算法

    啊居然要特判,卡了好久QAQ (好像Windows下的rand和Linux下的不一样? QwQ一些东西参考了喵铃的这篇blog:http://www.cnblogs.com/meowww/p/6400 ...

  10. Linux简单复习

    cd 命令:切换目录 ls命令:用于浏览目录下的文件或者文件夹 rm 命令:用于删除文件或者目录,用法 rm –rf test.txt (-r表示递归,-f表示强制) cp 命令:用于拷贝文件,用法, ...