MongoDB的安装及CURD操作
MongoDB的下载地址:http://www.mongodb.org/downloads MongoDB有32bit和64bit两个版本,32bit只能存放2GB数据。我们选择64bit版进行下载。
下载完成之后就行安装。不再赘述。
启动MongoDB服务器
打开windows命令行,进入安装目录:

然后,使用命令 mongod –-dbpath d:\mongodb\db 启动服务器:

当服务器启动以后,我们的文件系统如下:

连接MongoDB服务器
使用命令 mongo 连接服务器:

此时连接的是我们本机的MongoDB,可以看到当前MongoDB的版本号,以及连接的数据库名称。
指定远程服务器:
mongo 192.168.1.200
指定远程服务器、端口号:
mongo 192.168.1.200:27017
指定远程服务器、端口号、数据库:
mongo 192.168.1.200:27017/mydb
指定远程服务器、端口号、数据库、用户名、密码(未测试):
mongo 192.168.1.200:27017/mydb –u user –p password
在连接服务器之后,我们就可以进行CURD操作了。
数据库信息
使用命令db查看当前使用的数据库

使用use命令切换数据库。MongoDB的数据库在使用前不需要创建,直接use就可以了。数据表也是这样。

基本概念
文档:文档是一组键值对,可以理解为数据行。例如:
{name:"Tom", age:12}
集合:集合是一个文档的集合,可以理解为数据表。集合存在于数据库中,且集合中的文档可以拥有不同的结构。
数据库:数据库是一个集合的物理容器,MongoDB的数据库对应到自己设定的文件系统上面。
插入操作(insert)
在插入数据的时候,我们首先要选择要插入的集合。例如要将数据插入的user集合中,那么我们可以使用如下命令:
db.user.insert({name:"Tom", age:12})
执行效果如图:

集合中的文档可以有用不同的结构,例如我们也可以把下面的文档插入到user集合中:
db.user.insert({name:"Jerry", sex:0})
批量插入:
var list = [{name:"Jack", age:13}, {name:"Lucy", age:12}];
db.user.insert(list);
执行效果如图:

查询操作
使用find进行查找:
db.user.find()
目前我们的集合中有四行数据,不带参数的时候会返回所有文档:

我们会看到文档中有一个_id字段,这是MongoDB自动生成的,用来标记文档唯一性的,我们也可以自己指定这个值。
参数查找
转自一线码农:《8天学通MongoDB》系列
日常开发中,我们玩查询,玩的最多的也就是二类:
①: >, >=, <, <=, !=, =。
②:And,OR,In,NotIn
这些操作在mongodb里面都封装好了,下面就一一介绍:
<1>"$gt", "$gte", "$lt", "$lte", "$ne", "没有特殊关键字",这些跟上面是一一对应的,举几个例子。

<2> "无关键字“, "$or", "$in","$nin" 同样我也是举几个例子

<3> 在mongodb中还有一个特殊的匹配,那就是“正则表达式”,这玩意威力很强的。

<4> 有时查询很复杂,很蛋疼,不过没关系,mongodb给我们祭出了大招,它就是$where,为什么这么说,是因为$where中的value
就是我们非常熟悉,非常热爱的js来助我们一马平川。

更新操作
使用update进行更新,更新的参数有三个,第一个是更新条件,第二个是新的文档,第三个是更新的选项,可以忽略。
例如我们要更新Tom的年龄:
db.user.update({name:"Tom"}, {name:"Tom", age:15})
执行结果如下:

注意,这种更新是完整的更新,如果不给出name的值,将会把name字段删除掉。下面的内容来自一线码农:
<1> 整体更新
不知道大家可还记得,我在上一篇使用update的时候,其实那种update是属于整体更新。

<2> 局部更新
有时候我们仅仅需要更新一个字段,而不是整体更新,那么我们该如何做呢?easy的问题,mongodb中已经给我们提供了两个
修改器: $inc 和 $set。
① $inc修改器
$inc也就是increase的缩写,学过sql server 的同学应该很熟悉,比如我们做一个在线用户状态记录,每次修改会在原有的基础上
自增$inc指定的值,如果“文档”中没有此key,则会创建key,下面的例子一看就懂。

② $set修改器
啥也不说了,直接上代码

<3> upsert操作
这个可是mongodb创造出来的“词”,大家还记得update方法的第一次参数是“查询条件”吗?,那么这个upsert操作就是说:如果我
没有查到,我就在数据库里面新增一条,其实这样也有好处,就是避免了我在数据库里面判断是update还是add操作,使用起来很简单
将update的第三个参数设为true即可。

<4> 批量更新
在mongodb中如果匹配多条,默认的情况下只更新第一条,那么如果我们有需求必须批量更新,那么在mongodb中实现也是很简单
的,在update的第三个参数中,讲multi设置为true:
db.user.update({},{$inc:{age:1}},{multi:true})
删除操作
直接使用remove进行删除,如果不带参数,则会提示需要一个参数:

也就是说remove操作必须要带一个参数,例如我们要删除user中的所有数据,我们可以使用下面的命令:
db.user.remove({})
执行效果如图:

本文参考并转自一线码农:《8天学通MongoDB》系列
本文发表在 http://www.qeefee.com/article/000558
MongoDB的安装及CURD操作的更多相关文章
- MongoDB安装、CURD操作、使用场景分析总结(1)
NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL".非关系型的数据存储 MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 ...
- mongodb的安装与简单操作
MongoDB中文社区:http://www.mongoing.com 数据库的使用场景 SQL(关系型数据库):MySQL.SQLServer --->磁盘操作 1.高度事务性的场景 ...
- MongoDB的安装与python操作MongoDB
一.安装MongoDB 因为我个人使用的是windows,就只记录下windows下的安装 1.下载安装 就是官网,下载msi,选个路径安装 2.配置 看见别的地方说需要手动在bin同级目录创建dat ...
- mongodb数据库安装及常见操作
客户端和服务端的安装 # rpm -ivh mongo-10gen-2.4.6-mongodb_1.x86_64.rpm mongo-10gen-server-2.4.6-mongodb_1.x86_ ...
- mongodb的安装和sql操作
mongodb安装环境:centos6.5https://www.mongodb.org/dl/linux/x86_64wget https://fastdl.mongodb.org/linux/mo ...
- 【三】MongoDB文档的CURD操作
一.插入文档 使用insert方法插入文档到一个集合中,如果集合不存在创建集合,有以下几种方法: db.collection.insertOne({}):(v3.2 new) #插入一个文档到集合中 ...
- MongoDB学习(1)--安装,基本curd操作
知识点: 1-MongoDB 安装,启动和卸载 2-基本概念 3-基本的增删改查操作(CURD) 来回顾总结一把学习的mongodb,如果有javascript基础,学习"芒果DB" ...
- MongoDB安装、CURD增改查删操作、应用场景
NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL".非关系型的数据存储 MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 ...
- windows下mongodb基础玩法系列二CURD操作(创建、更新、读取和删除)
windows下mongodb基础玩法系列 windows下mongodb基础玩法系列一介绍与安装 windows下mongodb基础玩法系列二CURD操作(创建.更新.读取和删除) windows下 ...
随机推荐
- jQuery插件---exselect实现联动
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title> ...
- -Dmaven.multiModuleProjectDirectory system propery is not set. Check $M2_HOME environment variable and mvn script match.
一, eclipse中使用maven插件的时候,运行run as maven build的时候报错 -Dmaven.multiModuleProjectDirectory system propery ...
- PHP 异常
<?php /* PHP 异常处理 什么是异常? PHP 5 提供了一种新的面向对象的错误处理方法. 异常处理用于在指定的错误(异常)情况发生时改变脚本的正常流程. 这种情况称为异常. 当异常被 ...
- 1017关于EXPLAIN的语法
转自博客 http://blog.csdn.net/zhuxineli/article/details/14455029 explain显示了MySQL如何使用索引来处理select语句以及连接表.可 ...
- 网络设计中需要考虑的时延latency差异
Jeff Dean提到不同数据访问方式latency差异 Numbers Everyone Should Know L1 cache reference 0.5 ns Branch mispredic ...
- 选项卡js
趁着公司不忙,抓紧充充电,开始可能会写的不好,但是每写一个都是一点进步,哈哈,加油 用js实现选项卡切换 1.获取元素 2.初始状态 3.通过循环清空元素状态 4.点击操作以及对应的内容切换 5.自定 ...
- [转]easyui tree 模仿ztree 使用扁平化加载json
原文地址:http://my.oschina.net/acitiviti/blog/349377 参考文章:http://www.jeasyuicn.com/demo/treeloadfilter.h ...
- 自定义的ViewGroup中添加自定义View 造成的无法显示问题(个人)
首先说一下我在网上找了很久没有找到说明方法所以我就自己试着写了一下 1.我自定义了一个继承了RelativeLayout的ViewGroup java代码如下: /** * 简单自定义三头像 * @a ...
- 超级详细的iptable教程文档
Iptabels是与Linux内核集成的包过滤防火墙系统,几乎所有的linux发行版本都会包含Iptables的功能.如果 Linux 系统连接到因特网或 LAN.服务器或连接 LAN 和因特网的代理 ...
- php COOKIE和SESSION的一些理解
web服务器是基于http协议的,而http协议是无状态的,导致任意两个请求之间没有联系.但是我们登录网站后,它却能记住我们的身份,这个过程中一定使用了某个标识来区别我们的身份.对于简单数据传输的我们 ...