MongoDB入门,安装配置与基本CURD操作
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操作的更多相关文章
- Mybatis学习第一天——Mybatis的安装配置以及基本CURD操作
1.Mybatis下载 Mybatis是开源的持久层框架,能够度jdbc进行简单的封装,但其并不是完全的ORM(Object Relational Mapping,对象关系映射),无法脱离数据库进行适 ...
- MongoDB的安装配置、基本操作及Perl操作MongoDB
MongoDB的安装配置.基本操作及Perl操作MongoDB http://www.myhack58.com/Article/60/63/2014/42353.htm
- windows下mongodb基础玩法系列二CURD操作(创建、更新、读取和删除)
windows下mongodb基础玩法系列 windows下mongodb基础玩法系列一介绍与安装 windows下mongodb基础玩法系列二CURD操作(创建.更新.读取和删除) windows下 ...
- Linux入门总结——虚拟机安装配置以及vim简单操作
安装配置ubuntu 安装准备 vittualbox-5.2.22版本(win10) ubuntu-12.04 安装VirtualBox 1.双击VirtualBox-5.2.2-119230-Win ...
- 概述hibernate入门安装配置
1.jdbc连接的优缺点 JDBC的优点 直接底层操作,提供了很简单.便捷的访问数据库的方法,跨平台性比较强.灵活性比较强,可以写很复杂的SQL语句. JDBC的缺点 1).因为JAVA是面向对象的, ...
- Linux环境下NodeJS和MongoDB的安装配置
一.NodeJS的安装配置 #进入安装目录cd /usr/local/ #删除原有安装rm -rf noderm -rf node-v0.10.29-linux-x64 #解压压缩包tar -zxv ...
- MongoDB下载+安装+配置+错误解决方法
下载 官网下载: https://www.mongodb.com/download-center/community Server=>Download 安装 下载完成后安装 建议下载根目录(下过 ...
- MongoDB(二)——安装配置了解
前边介绍了MongoDB的大概理论知识,这篇来对MongoDB进行一下安装使用,支持安装在windows和linux上,当然了很多其它情况下我们是安装在linux上,由于毕竟server用linux的 ...
- mysql 安装配置及经常使用操作
作为关系型数据库的一种,mysql因其占用内存小和开源等特性而兴起.以下简介下关于mysql配置和简单的操作. mysql配置 1.安装文件的下载 免安装版下载地址 :http://dev.mysql ...
随机推荐
- PCIe相关的操作命令
1.lspci --显示列举系统目前的pcie设备 43:00.0 Class 0004: Device 104c:b800 (rev 01) //netra设备 设备编号 ...
- highcharts图表显示鼠标选择的Y轴提示线
tooltip: { shared: true, crosshairs: [true, false] },
- Python数据库(一)-Mysql数据库的连接
首先需要安装pymysql模块 然后用pymysql连接mysql并执行命令来查看数据 连接mysql数据库后需要创建游标来执行SQL语句 # -*- coding:utf-8 -*- __autho ...
- css 文件上传按钮美化
转自:http://zixuephp.net/article-85.html 思路:在一个div里面添加一个图片用作按钮再添加一个input file 文件上传,把文件上传按钮设置透明度为0,绝对定位 ...
- 【转载】C语言综合实验1—学生信息管理系统
http://www.cnblogs.com/Anker/archive/2013/05/06/3063436.html 实验题目:学生信息管理系统 实验要求:用户可以选择1-7可以分别进行学生信息的 ...
- mybatis中in查询
xml配置 : <select id="selectPostIn" resultType="dasyskjcdtblVo"> SELECT SYS_ ...
- python爬虫实战(2)--爬取百度贴吧
本篇目标 1.对百度贴吧的任意帖子进行抓取 2.指定是否只抓取楼主发帖内容 3.将抓取到的内容分析并保存到文件 1.URL格式的确定 先观察百度贴吧url格式,以中南财经政法大学迎新帖为例,URL我们 ...
- java 类中 static 的使用
在类中 static 主要修饰变量,方法及代码块.大致的执行和使用,据个人理解如下: 1.修饰变量: 在修饰变量时,如 ,表示该变量是静态变量,也可称为类变量.当当前变量是静态变量时,该变量被该类的所 ...
- ROS探索总结(六)——使用smartcar进行仿真
转自:https://www.ncnynl.com/archives/201609/843.html 总结: 一.机器人描述文件三个: 机器人主体body文件: gazebo属性文件: 主文件 sma ...
- .NET回归 HTML----表单元素(1)和一些常用的标记
表单就是-----用于搜集不同类型的用户输入. 表单元素指的是不同类型的 input 元素.复选框.单选按钮.提交按钮等等. 首先将表单元素分为三个类型.文本类,按钮类,选择类. 表单可以嵌套在表中, ...