MongoDB 基础手册(一)
作者:云怀大师兄
博客园: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 基础手册(一)的更多相关文章
- mongodb基础用法
安装部分 mongodb配置方法 mongodb的安装目录 C:\MongoDB\Server\3.2\bin 创建以下目录 c:\mongo\log c:\mongo\db 创建mongodb的配置 ...
- mongodb基础系列——数据库查询数据返回前台JSP(一)
经过一段时间停顿,终于提笔来重新整理mongodb基础系列博客了. 同时也很抱歉,由于各种原因,没有及时整理出,今天做了一个demo,来演示,mongodb数据库查询的数据在JSP显示问题. 做了一个 ...
- MongoDB基础知识 02
MongoDB基础知识 02 6 数据类型 6.1 null : 表示空值或者不存在的字段 {"x":null} 6.2 布尔型 : 布尔类型只有两个值true和false {&q ...
- MongoDB基础知识 01
MongoDB基础知识 1. 文档 文档是MongoDB中的数据的基本单元,类似于关系型数据库管理系统的行. 文档是键值对的一个有序集.通常包含一个或者多个键值对. 例如: {”greeting& ...
- MongoDB基础教程系列--未完待续
最近对 MongoDB 产生兴趣,在网上找的大部分都是 2.X 版本,由于 2.X 与 3.X 差别还是很大的,所以自己参考官网,写了本系列.MongoDB 的知识还是很多的,本系列会持续更新,本文作 ...
- DataBase MongoDB基础知识记录
MongoDB基础知识记录 一.概念: 讲mongdb就必须提一下nosql,因为mongdb是nosql的代表作: NoSQL(Not Only SQL ),意即“不仅仅是SQL” ,指的是非关系型 ...
- MongoDB 基础(2019年开篇)
MongoDB基础知识: 1.什么是MongoDB NoSQL(NoSQL=Not Only SQL),意即"不仅仅是SQL". MongoDB是一个介于关系数据库和非关系数据库之 ...
- MongoDB基础学习
*:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...
- windows下mongodb基础玩法系列二CURD附加一
windows下mongodb基础玩法系列 windows下mongodb基础玩法系列一介绍与安装 windows下mongodb基础玩法系列二CURD操作(创建.更新.读取和删除) windows下 ...
随机推荐
- Leetcode学习笔记(2)
题目1 ID面试题 01.04 给定一个字符串,编写一个函数判定其是否为某个回文串的排列之一. 回文串是指正反两个方向都一样的单词或短语.排列是指字母的重新排列. 回文串不一定是字典当中的单词. 示例 ...
- leetcode计划
5.17 星期日,应完成的下周leetcode题目:279,300,1143,72,(前4个动态规划),104,110,543(后三个关于树)(https://cyc2018.github.io/CS ...
- 如何实现OSM地图本地发布并自定义配图
目录 1.缘起 2.准备环境 2.1.安装linux系统 2.2.安装docker 2.3.安装Docker Compose 2.4.安装git 3.发布地图 3.1.拉取代码 3.2.测试网络 3. ...
- P7077 函数调用
我好蠢啊... 考试的时候不会写,现在看了这么多篇题解还是似懂非懂,所以决定写一下草稿... 草稿 和 题解 就是首先,题目保证了函数不会间接的调用其本身,所以可以直接知道这是一个 \(\text{D ...
- Java IO源码分析(二)——ByteArrayInputStream 和 ByteArrayOutputStream
简介 ByteArrayInputStream 是字节数组输入流,它继承于InputStream. 它的内部数据存储结构就是字节数组. ByteArrayOutputStream是字节数组输出流,它继 ...
- Cloudera Manager API使用
Cloudera Manager提供了很多API供用户进行访问,因此可以利用其提供的API进行大数据集群中各种服务的状态检测.监控以及服务的启停操作. 版本信息 Cloudera Manager 6. ...
- springmvc中使用文件下载功能
项目代码:https://github.com/PeiranZhang/springmvc-fileupload 使用文件下载步骤 对请求处理方法使用void或null作为返回类型,并在方法中添加Ht ...
- java-02-基础语法
1.分支语句 if语句 格式 if(关系表达式1){语句1} else if(关系表达式2){语句2} else{语句3}; 说明 如果关系表达式1的值为true,执行语句1. 如果关系表达式2的值为 ...
- [打基础]luogu1957口算练习题——字符串基本操作
题意:第一行给出数据组数n,之后n行每行给出三个或两个数据,若给三个数据,则第一个数据用单个字符a/b/c分别表示+/-/*运算,后两个数表示参与运算的数字,若给两个数据延续之前的运算 要求对每行数据 ...
- Eureka系列(七) 服务下线Server端具体实现
服务下线的大致流程图 下面这张图很简单地描述了Server端服务下线的大致流程: 服务下线Server端实现源码分析 Eureka服务实现是通过Server端InstanceResource ...