1. MongoDB: 是NOSQL的一种, 特长是分布式用的,用于处理爬虫数据
2. mongoDB 与 redis

mongoDB是最像关系型的非关系型数据,更加适用于大数据,redis则更倾向于,并发较小,数据较小,性能更高
3. MongoDB的默认端口: 27017
4. 重要概念
MongoDB mysql
数据库 数据库
集合 表
文档(类似字典) 记录
键值对 字段 #注意: MongoDB中是区分大小写, mysql是不区分大小写
#注意: MongoDB中表示id的是"_id"
5. 用户管理
权限是数据区来做区分的
想要操作admin 那就在admin下创建用户
想要操作adb 那就在adb下创建用户
6. 创建用户

use admin   #使用admin 数据库
db.createUser({
"user":"root",
"pwd":"123",
roles:[{"role":"root","db":"admin"}]
})
####在admin 数据库内创建用户 , 用户root, 密码为123 权限是root权限, 操作admin库
key都是固定的不能随便写每一个key都有特殊含义
其中{"role": "root"} role固定的key root是角色的名字 有可选范围如root readWrite read等等...
7.如何设置Mongdb的用户认证功能:
找到配置文件中(bin下) 修改mongod.cfg 增加一个配置项:
security:
authorization: enabled
# 注意缩进
8. 登录方式: mongo -u "root" -p "123"
或者: mongo 直接进行游客模式 use 切换到与用户所在的数据库 db.auth("用户名","密码") 返回1为成功 0为失败
use 数据库名字  创建数据库
例如: use mydb #创建数据库mydb 因为里面,没有数据,所以不显示出来 db.dropDatabase() 删除数据库 show dbs 查看所有数据库, #因为mydb 没有添加数据所以不会显示出来 use 切换数据库,#切换数据 如果不存在会自动创建 新建的数据库是查看不到的 因为里面没有数据

库的操作

集合的操作(表的操作):
use mydb
dd.tt #创建表,但是没数据,还是不显示 show tables #查看所有集合
db.info.drop() #删除集合 记录文档的操作:
db.user.insert({"_id":1}) #插入一条数据 db.user.insertMany([
{"_id": 3, "name": "张三封"},
{"_id": 4, "name": "鹌鹑蛋"}
])
##插入多条数据 也可以这样:
user1={
"_id":1,
"name":"alex",
"age":10,
'hobbies':['music','read','dancing'],
'addr':{
'country':'China',
'city':'weifang'
}
}
db.user.insert(user1) #插入变量:
user1 = {"_id":10,"name":"王五"}
db.user.insert(user1) #如果id已经存在则覆盖, 没有添加
db.user.save( {"_id":10,"name":"鹌鹑蛋2"}) #因为已经存在,所以,王五变为鹌鹑蛋2 db.user.find() #查询
db.user.find().pretty() #查询结果格式化 #语句查询:
db.user.find() # 查询所有 == select *from user db.user.find({"name":"张三封"}) == select *from user where name = "张三封"
#查询名字为张三封 全部显示出来
db.user.find({"name":"张三封","_id":3}) == select *from user where name = "张三封 and _id = 3"
#查询名字为张三封 且_id 为3 全部显示出来 #比较运算符
> < != >= <=
gt lt ne gte lte db.user.find({"name":{"$ne":"张三封"}}) db.user.find({"_id":{"$gt":3}}) #注意:字段名在外层 条件在里层 逻辑运算符
and or not db.user.find({"$or":[
{"name":"张三丰"},
{"name":"鹌鹑蛋"}
]}) ============================================================================= 取反
db.user.find({"_id":{"$not":{"$mod":[2,1]}}}) # id 在 [1,2]内的
db.user.find({
"_id":{"$in":[1,2]}
}) # id 不在 [1,2]内的
db.user.find({
"_id":{"$nin":[1,2]}
}) # 查询指定字段
db.user.find({},{"name":1,"_id":0})
1表示展示 0不展示
_id默认为1 其他默认为0 db.student.find({"hobbies":{"$all":["movie","muisc"]}}) db.student.find({"hobbies.1":"girl"}) #按照索引进行查询,1是数组的索引 # 查看所有人的 第一个和第二个爱好
db.student.find({},{"hobbies":{"$slice":[0,1]}}) # $slice [1,1] 表示的是从第1个开始取1个
db.student.find({},{"hobbies":{"$slice":[1,1]}})

表的操作




												

MongoDB 全部笔记的更多相关文章

  1. MongoDB学习笔记系列

    回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...

  2. PHP操作MongoDB学习笔记

    <?php/*** PHP操作MongoDB学习笔记*///*************************//**   连接MongoDB数据库  **////*************** ...

  3. MongoDB 学习笔记(原创)

    MongoDB 学习笔记 mongodb 数据库 nosql 一.数据库的基本概念及操作 SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table ...

  4. mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)

    最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...

  5. MongoDB学习笔记(转)

    MongoDB学习笔记(一) MongoDB介绍及安装MongoDB学习笔记(二) 通过samus驱动实现基本数据操作MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB ...

  6. 【转】MongoDB学习笔记(查询)

    原文地址 MongoDB学习笔记(查询) 基本查询: 构造查询数据. > db.test.findOne() { "_id" : ObjectId("4fd58ec ...

  7. MongoDB学习笔记(六)--复制集+sharding分片 && 总结

    复制集+sharding分片                                                               背景 主机 IP 服务及端口 Server A ...

  8. MongoDB学习笔记(五)--复制集 && sharding分片

    主从复制                                                                                       主从节点开启 主节 ...

  9. MongoDB学习笔记(四)--索引 && 性能优化

    索引                                                                                             基础索引 ...

  10. MongoDB学习笔记(三)--权限 && 导出导入备份恢复 && fsync和锁

    权限                                                                                             绑定内网I ...

随机推荐

  1. elasticsearch 5.1 别的机器无法访问9200端口

    版权声明:作者:jiankunking 出处:http://blog.csdn.net/jiankunking 本文版权归作者和CSDN共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显 ...

  2. Ubuntu 14.04不显示标题栏和侧边栏

    Ubuntu 14.04不显示标题栏和侧边栏 进入桌面后 Ctrl + Alt + F1 切换到 tty1,登录,然后运行: sudo apt-get install unity lightdm重启即 ...

  3. 写在vue总结之前(二)

    都说要快速学会一个技术(会使用),比如一个框架,在实际的工作中做相关的项目是最快的学习方式.而为什么在实际的工作项目中去学习是最快的方式?个人的体会是,在实际的工作项目中,很多功能的实现是你不得不做的 ...

  4. random 产生一个随机数的方法

    import random print( random.randint(1,10) ) # 产生 1 到 10 的一个整数型随机数 print( random.random() ) # 产生 0 到 ...

  5. 计时器setTimeout()

    setTimeout()计时器,在载入后延迟指定时间后,去执行一次表达式,仅执行一次. 语法: setTimeout(代码,延迟时间); 参数说明: 1. 要调用的函数或要执行的代码串. 2. 延时时 ...

  6. 信息安全-加密:AES 加密

    ylbtech-信息安全-加密:AES 加密 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一 ...

  7. NodeJs针对Express框架配置Mysql进行数据库操作

    Express版本:4.14.1 说明:如下配置以express为例进行配置并进行测试,当然mysql中间件也可以在nodejs中单独使用. 参考:NodeJs的Mysql中间件Github地址 1. ...

  8. Vue + TypeScript + ElementUI 封装表头查询组件

    前段时间有朋友私信我 Vue + TypeScript 的问题,然后就打算写一篇 Vue + TypeScript 封装组件的文章 正好公司项目中需要封装一个表头查询组件,就拿出来分享一下~ 组件的整 ...

  9. [UE4]使用name slot制作带背景的容器

    name slot相当于asp.net模板中的content模板. 可以往“Name Slot”里面拖放控件,如果没有“Name Slot”就不能给“BgPanel”拖放任何控件

  10. 运维人员word优化