MongoDB特点

MongoDB是NoSQL的一种,非关系型数据库,或者叫不只是关系型数据库(Not Only SQL)。MongoDB采用json格式的文档存储,与Redis的key-value有区别。每个json文档(每行)的结构可能是一样的,因此可以实现关系型数据库的部分功能,比如建立索引,条件查询。下面是基本概念对比

SQL NoSQL
MySQL MongoDB
database database
table collection
row document

MongoDB 安装与配置

  • 安装略
  • 启动服务端
  • 启动客户端连接
  • 配置用户

    MongoDB默认创建了几个库(db/schema),admin,config,local,test等。admin主要用来存储用户权限表。通过
db.createUser({user:'username', pwd:'userpass', roles:[{role:'readWrite', db:'test'}]})

来创建用户和赋予权限。普通db的用户权限有read, readWrite, dbAdmin, userAdmin.分别表示读,读写,db管理,用户管理。每个db可以有独立的用户权限表。

admin库的用户拥有更多角色权限。通常用来管理全局数据库的权限,root, readWriteAnyDatabase 等

认证用户之前需要选择用户创建的时候指定的库,比如上面的username

> use test
test
> db.auth('username', 'userpass')
1

MongoDB 增删改查

MongoDB的集合collection(table)一般不需要创建可以直接使用。

> use test
test
> db.newCollection.insert({name:'dapianzi', say:'hello world'})

MongoDB 有一种固定大小的集合,通常用来存储日志,超过大小限制之后会从头开始覆盖写入。这种集合需要显式创建

> db.createCollection("mycol", { capped : true, autoIndexId : true, size : 6142800, max : 10000 } )
{ "ok" : 1 }
>

collection的名字可以包含空格和-,可以使用保留字。但是在shell中无法使用db.collectionName的形式,需要用db.getCollection:

db.getCollection("3 test").find()
db.getCollection("3-test").find()
db.getCollection("stats").find()
  • Insert 操作

    其他方法比如update,save,findAndUpdate 通过设置 {upsert: true} 也可以插入新数据
    db.collection.insert({document:"document1"})
db.collection.insertOne({document:"document2"})
db.collection.insertMany([{document:"document3"},{document:"document4"}])
  • update / save

  • delete

  • query -- db.collection.find(option)

    @see Query Documents — MongoDB Manual 3.6

    MongoDB通过组合json查询条件实现不同查询需求, 常用的有 $or, $gt, $in, $gte 等,支持正则表达式查询。
db.collection.find({name:/^w/})
//相当于
SELECT * FROM table WHERE name LIKE 'w%'

如果文档内容是嵌入的文档(json),可以通过下面两种方式查询:

db.collection.find({item: {subKey: 'a', subName:'b'}})
db.collection.find({'item.subKey':'a', 'item.subName':'b'})

查询数组列表有几个模式比较特别:

db.inventory.find( { tags: ["red", "blank"] } ) 数组tags等于["red","blank"]

db.inventory.find( { tags: { $all: ["red", "blank"] } } ) 数组包含red和blank,不限顺序和是否还有其他元素

db.inventory.find( { dim_cm: { $gt: 15, $lt: 20 } } ) 数组里存在元素x>15,同时存在元素y<20的元素

db.inventory.find( { dim_cm: { $elemMatch: { $gt: 22, $lt: 30 } } } ) 至少存在一个元素x同时满足15<x<20

MongoDB 主从复制,分布式架构

MongoDB支持多种架构,从简单的主备复制,到分布式存储都有成熟的体系可以直接应用。可以简单了解一下,遇到需要应用的场景时再仔细研究。

MongoDB的初步学习暂时就到这里,下一篇将重点学习MongoDB的聚合查询,全文索引等。

MongoDB入门,安装配置与基本CURD操作的更多相关文章

  1. Mybatis学习第一天——Mybatis的安装配置以及基本CURD操作

    1.Mybatis下载 Mybatis是开源的持久层框架,能够度jdbc进行简单的封装,但其并不是完全的ORM(Object Relational Mapping,对象关系映射),无法脱离数据库进行适 ...

  2. MongoDB的安装配置、基本操作及Perl操作MongoDB

    MongoDB的安装配置.基本操作及Perl操作MongoDB http://www.myhack58.com/Article/60/63/2014/42353.htm

  3. windows下mongodb基础玩法系列二CURD操作(创建、更新、读取和删除)

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

  4. Linux入门总结——虚拟机安装配置以及vim简单操作

    安装配置ubuntu 安装准备 vittualbox-5.2.22版本(win10) ubuntu-12.04 安装VirtualBox 1.双击VirtualBox-5.2.2-119230-Win ...

  5. 概述hibernate入门安装配置

    1.jdbc连接的优缺点 JDBC的优点 直接底层操作,提供了很简单.便捷的访问数据库的方法,跨平台性比较强.灵活性比较强,可以写很复杂的SQL语句. JDBC的缺点 1).因为JAVA是面向对象的, ...

  6. Linux环境下NodeJS和MongoDB的安装配置

     一.NodeJS的安装配置 #进入安装目录cd /usr/local/ #删除原有安装rm -rf noderm -rf node-v0.10.29-linux-x64 #解压压缩包tar -zxv ...

  7. MongoDB下载+安装+配置+错误解决方法

    下载 官网下载: https://www.mongodb.com/download-center/community Server=>Download 安装 下载完成后安装 建议下载根目录(下过 ...

  8. MongoDB(二)——安装配置了解

    前边介绍了MongoDB的大概理论知识,这篇来对MongoDB进行一下安装使用,支持安装在windows和linux上,当然了很多其它情况下我们是安装在linux上,由于毕竟server用linux的 ...

  9. mysql 安装配置及经常使用操作

    作为关系型数据库的一种,mysql因其占用内存小和开源等特性而兴起.以下简介下关于mysql配置和简单的操作. mysql配置 1.安装文件的下载 免安装版下载地址 :http://dev.mysql ...

随机推荐

  1. VisualGDB系列8:使用VS创建CMake Linux项目

    根据VisualGDB官网(https://visualgdb.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指正. 本文介绍如何使用VS来创建.构建.调试一 ...

  2. Mongodb 3.6 副本集测试及添加删除节点等操作

    下载tar包并安装curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.6.8.tgz [root@mysqlt ...

  3. Redis 集群之 Redis-Cluster

    Redis集群官方推荐方案 Redis-Cluster 集群 redis cluster 通过分片实࣫容量扩展 通过主从复制实࣫节点的高可用 节点之间互相通信 每个节点都维护整个集群的节点信息 red ...

  4. .Net 之Tuple 类

    Tuple是什么 按照Msdn 上说:提供用于创造元组对象的静态方法.从字面意思并不能理解他的作用:   Tuple 是个静态类,提供8个静态泛型方法:T 可以是值类型,也可是引用类型:   使用场景 ...

  5. mysql的默认隔离级别

    原文:https://www.cnblogs.com/rjzheng/p/10510174.html 知识点总结 ------------------------------------------- ...

  6. SqlServer——判断对象是否存在

    对以下对象判断是否存在:database.table.proc.触发器.临时表.索引.对于这些对象的判断是通过数据表 SysObjects来获得的. 一.基础知识 1.SysObjects系统表 对于 ...

  7. Shell编程进阶 2.2 shell数组

    给一个字符指定一个数组 怎么显示数组 a= echo $a a=( ) echo $a echo ${a[@]} echo ${a[*]} 指定显示数组中第几个数字 echo ${a[]} echo ...

  8. Excel向数据库插入数据和数据库向Excel导出数据

    为了熟悉java里工作簿的相关知识点,所以找了“Excel向数据库插入数据和数据库向Excel导出数据”的功能来实现. 注意事项:1,mysql数据库: 2,需要导入的jar包有 jxl.jar,my ...

  9. C语言学习笔记--内存分区

    1. 程序中的栈 1.1 栈的简介 (1)栈中现代计算机程序里最为重要的概念之一 (2)栈在程序中用于维护函数调用上下文 (3)函数中的参数和局部变量存储在栈上 (4)栈保存了一个函数调用所需的维护信 ...

  10. 如何边遍历集合边删除元素--使用Iterator中的remove()方法

    在遍历集合时,想将符合条件的某些元素删除,开始是用了下面的方法 public static void main(String[] args) throws UnsupportedEncodingExc ...